[Qt教程] 第21篇 数据库(一)Qt数据库应用简介

简介:
楼主
  发表于 2013-5-13 20:56:39  | 查看: 1403 | 回复: 13
Qt数据库应用简介
版权声明

该文章原创于作者yafeilinux,转载请注明出处!



导语

下面十节讲解数据库和XML的相关内容。在学习数据库相关内容前,建议大家掌握一些基本的SQL知识,应该可以看懂基本的SELECT、INSERT、UPDATE和DELETE等语句,因为在这几篇教程中使用的都是非常简单的操作,所以即便没有数据库的专业知识也可以看懂!



环境: Windows Xp + Qt 4.8.4+Qt Creator2.6.2



目录

一、数据库简介
二、数据库驱动
三、简单的数据库应用


正文


一、数据库简介

Qt中的QtSql模块提供了对数据库的支持,该模块中的众多类基本上可以分为三层,如下图所示。

21-1.jpg

        其中驱动层为具体的数据库和SQL 接口层之间提供了底层的桥梁;SQL 接口层提供了对数据库的访问,其中的QSqlDatabase 类用来创建连接,QSqlQuery 类可以使用SQL 语句来实现与数据库交互,其他几个类对该层提供了支持;用户接口层的几个类实现了将数据库中的数据链接到窗口部件上,这些类是使用前一章的模 型/视图 框架实现的,它们是更高层次的抽象,即便不熟悉SQL 也可以操作数据库。如果要使用QtQql 模块中的这些类,需要在项目文件(.pro 文件)中添加QT += sql 这一行代码。对应数据库部分的内容,大家可以在帮助中查看 SQL Programming 关键字。


二、数据库驱动

QtSql模块使用数据库驱动来和不同的数据库接口进行通信。由于Qt的SQL模型的接口是独立于数据库的,所以所有数据库特定的代码都包含在了这些驱动中。Qt现在支持的数据库驱动如下图所示。

21-2.jpg

需要说明的是,由于GPL许可证的兼容性问题,并不是这里列出的所有驱动插件都提供给了Qt的开源版本。下面我们通过程序来查看一下现在版本的Qt中可用的数据库插件。


1. 新建Qt  控制台应用,名称为sqldrivers


2. 完成后将sqldrivers.pro 项目文件中第一行代码更改为:

QT        += core sql

表明使用了sql 模块,然后按下Ctrl + S 快捷键保存该文件。


3. main.cpp 文件的内容更改如下:
#include   <QCoreApplication>
#include   <QSqlDatabase>
#include   <QDebug>
#include   <QStringList>
int   main( int   argc,   char   *argv[])
{
     QCoreApplication   a(argc,   argv);
     qDebug()   <<   "Available drivers:" ;
     QStringList   drivers   =   QSqlDatabase :: drivers();
     foreach ( QString   driver,   drivers)
        qDebug()   <<   driver;
     return   a.exec();
}
     这里先使用drivers()函数获取了现在可用的数据库驱动,然后分别进行了输出。运行程序,结果如下图所示。
21-3.jpg


        可以发现,现在只支持三个数据库。这里要重点提一下SQLite 数据库,它是一款轻型的文件型数据库,主要应用于嵌入式领域,支持跨平台,而且Qt 对它提供了很好的默认支持,所以在本章后面的内容中,我们将使用该数据库作为例子来进行讲解。


三、简单的数据库应用
        下面使用QSLite 数据库来进行一个简单的演示,创建一个数据库表,然后查找其中的数据并进行输出。我们更改main.cpp 文件的内容如下:

  1. #include <QCoreApplication>
  2. #include <QSqlDatabase>
  3. #include <QDebug>
  4. #include <QSqlQuery>

  5. int main(int argc, char *argv[])
  6. {
  7.     QCoreApplication a(argc, argv);

  8.     //添加数据库驱动
  9.     QSqlDatabase db = QSqlDatabase::addDatabase("QSQLITE");
  10.     //数据库连接命名
  11.     db.setDatabaseName(":memory:");
  12.     //打开数据库
  13.     if(!db.open())
  14.     {
  15.         return false;
  16.     }

  17.     //以下执行相关sql语句
  18.     QSqlQuery query;

  19.     //新建student表,id设置为主键,还有一个name项
  20.     query.exec("create table student(id int primary key,name varchar)");

  21.     //向表中插入3条记录
  22.     query.exec("insert into student values(1,'xiaogang')");
  23.     query.exec("insert into student values(2,'xiaoming')");
  24.     query.exec("insert into student values(3,'xiaohong')");

  25.     //查找表中id >=2 的记录的id项和name项的值
  26.     query.exec("select id,name from student where id >= 2");

  27.     //query.next()指向查找到的第一条记录,然后每次后移一条记录
  28.     while(query.next())
  29.     {
  30.         //query.value(0)是id的值,将其转换为int型
  31.         int value0 = query.value(0).toInt();
  32.         QString value1 = query.value(1).toString();
  33.         //输出两个值
  34.         qDebug() << value0 << value1 ;
  35.     }

  36.     return a.exec();
  37. }
复制代码
这里使用了SQLite数据库,连接名为“:memory:”表示这是建立在内存中的数据库,也就是说该数据库只在程序运行期间有效。如果需要保存该数据库文件,我们可以将它更改为实际的文件路径。程序中使用到的QSqlQuery类,将在后面的内容中讲到。运行程序,结果如下图所示。

21-4.jpg



结语

        本节简单介绍了一下Qt 中数据库相关的内容,可以看到,现在Qt 支持的数据库仅有两类。如何才能让Qt 支持其他的数据库呢,下一节,我们将以现在广为使用的MySql 为例,讲解数据库驱动的编译。如果大家想系统的学习Qt 数据库部分内容,可以参考 《Qt Creator快速入门》 的第17 章。



涉及到的源码:  sqldrivers.zip (1.36 KB, 下载次数: 10) 
相关文章
|
6天前
|
存储 安全 搜索推荐
酒店管理系统的数据库的应用以及选择
酒店管理系统数据库关乎运营效率和服务质量。数据库用于数据存储、管理、分析及客户关系管理,确保房态与预订精准。选择时重视性能稳定性、数据安全、易用性、可扩展性和成本效益。合适的数据库能提升酒店运营效率并优化客户体验。
19 2
|
17天前
|
SQL 数据库连接 API
Perl 教程 之 Perl 数据库连接 7
Perl DBI教程讲解了如何连接数据库,它是与数据库交互的标准接口,提供平台无关的访问。支持事务处理,可通过设置`AutoCommit =&gt; 0`在连接时开始事务或使用`$dbh-&gt;begin_work()`。事务结束后,用`commit`提交或`rollback`回滚。完成工作后,用`$dbh-&gt;disconnect`断开连接。
18 1
|
18天前
|
SQL 数据库连接 API
Perl 教程 之 Perl 数据库连接 4
Perl的DBI模块提供数据库独立接口,用于连接和操作数据库。通过prepare()预处理SQL,execute()执行,finish()释放句柄,及commit()提交事务。
12 1
|
26天前
|
SQL 关系型数据库 MySQL
阿里云MySQL数据库价格、购买、创建账号密码和连接数据库教程
阿里云数据库使用指南:购买MySQL、SQL Server等RDS实例,选择配置和地区,完成支付。创建数据库和账号,设置权限。通过DMS登录数据库,使用账号密码访问。同地域VPC内的ECS需将IP加入白名单以实现内网连接。参考链接提供详细步骤。
366 3
|
8天前
|
存储 传感器 监控
数据库的应用
数据库广泛应用于电子商务、物流、酒店管理、医疗、航空、教育、政府和物联网等领域,用于高效存储和管理商品信息、订单数据、医疗记录、航班详情等各类数据,提升效率和服务质量。随着技术进步,其应用场景将持续扩展。
10 1
|
15天前
|
NoSQL 大数据 数据挖掘
现代数据库技术与大数据应用
随着信息时代的到来,数据量呈指数级增长,对数据库技术提出了前所未有的挑战。本文将介绍现代数据库技术在处理大数据应用中的重要性,并探讨了一些流行的数据库解决方案及其在实际应用中的优势。
|
16天前
|
弹性计算 关系型数据库 MySQL
阿里云数据库服务器价格表,数据库创建、连接和使用教程
阿里云数据库使用流程包括购买和管理。选择所需数据库类型如MySQL,完成实名认证后购买,配置CPU、内存和存储。确保数据库地域与ECS相同以允许内网连接。创建数据库和账号,设置权限。通过DMS登录数据库,使用账号密码连接。同一VPC内的ECS需添加至白名单以进行内网通信。参考官方文档进行详细操作。
76 3
|
19天前
|
SQL 关系型数据库 数据库连接
Perl 教程 之 Perl 数据库连接 1
Perl教程:使用DBI模块实现数据库连接,DBI是数据库独立接口,适用于Oracle、MySQL等。它定义通用方法,通过API处理SQL,分配给驱动执行。常用变量如$dsn(数据库源),$dbh(数据库句柄),$sth(语句句柄),返回值用$rc和$rv,查询结果存入@ary或(rows)。文件操作用$fh,属性用%\attr。
143 2
|
26天前
|
弹性计算 关系型数据库 MySQL
阿里云MySQL云数据库优惠价格、购买和使用教程分享!
阿里云数据库使用流程包括购买和管理。首先,选购支持MySQL、SQL Server、PostgreSQL等的RDS实例,如选择2核2GB的MySQL,设定地域和可用区。购买后,等待实例创建。接着,创建数据库和账号,设置DB名称、字符集及账号权限。最后,通过DMS登录数据库,填写账号和密码。若ECS在同一地域和VPC内,可内网连接,记得将ECS IP加入白名单。
419 2
|
27天前
|
SQL 关系型数据库 MySQL
阿里云mysql数据库价格购买和使用教程
阿里云数据库使用指南:购买MySQL、SQL Server等RDS实例,通过选择配置、地域和可用区完成购买。创建数据库和账号,分配权限。使用DMS登录数据库,进行管理操作。确保ECS与RDS在同一地域的VPC内,配置白名单实现内网连接。详细步骤见官方文档。
626 1

推荐镜像

更多