找回密码
 立即注册
收起左侧

第21篇 Qt5之数据库(一)简介

3
回复
6314
查看
[复制链接]
累计签到:1070 天
连续签到:3 天
来源: 2017-6-6 23:47:12 显示全部楼层 |阅读模式
版权声明


该文章原创于Qt开源社区(www.qter.org),作者yafeilinux,转载请注明出处!


导语


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


环境:Windows 7 + Qt 5.8.0(包含Qt Creator 4.2.1)


目录


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




正文



一、数据库简介


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




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


二、数据库驱动


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




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


新建Qt 控制台应用(Qt Console Application,名称为sqldrivers。完成后将sqldrivers.pro项目文件中第一行代码更改为:QT += sql 表明使用了sql模块,然后按下Ctrl + S快捷键保存该文件。下面main.cpp文件的内容更改如下:


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

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

  8.     qDebug() << "Available drivers:";
  9.     QStringList drivers = QSqlDatabase::drivers();
  10.     foreach(QString driver, drivers)
  11.         qDebug() << driver;

  12.     return a.exec();
  13. }
复制代码



        这里先使用drivers()函数获取了现在可用的数据库驱动,然后分别进行了输出。运行程序,结果如下图所示。




        可以发现,现在支持7个数据库。这里要重点提一下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.     //创建一个SQLite数据库连接
  9.     QSqlDatabase db = QSqlDatabase::addDatabase("QSQLITE");
  10.     //数据库连接命名
  11.     db.setDatabaseName(":memory:");
  12.     //打开数据库
  13.     if(!db.open()) return false;

  14.     //以下执行相关sql语句
  15.     QSqlQuery query;
  16.     //新建student表,id设置为主键,还有一个name项
  17.     query.exec("create table student(id int primary key,name varchar)");
  18.     //向表中插入3条记录
  19.     query.exec("insert into student values(1,'xiaogang')");
  20.     query.exec("insert into student values(2,'xiaoming')");
  21.     query.exec("insert into student values(3,'xiaohong')");
  22.     //查找表中id >=2 的记录的id项和name项的值
  23.     query.exec("select id,name from student where id >= 2");
  24.     //query.next()指向查找到的第一条记录,然后每次后移一条记录
  25.     while(query.next())
  26.     {
  27.         //query.value(0)是id的值,将其转换为int型
  28.         int value0 = query.value(0).toInt();
  29.         QString value1 = query.value(1).toString();
  30.         //输出两个值
  31.         qDebug() << value0 << value1 ;
  32.     }

  33.     return a.exec();
  34. }
复制代码

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




结语


        本节简单介绍了一下Qt中数据库相关的内容,后面我们将主要使用SQLite数据库进行讲解,不过大家也经常使用MySql数据库,所以下一节将简单介绍下该数据库的安装使用

源码:




本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有帐号?立即注册

x
回复

使用道具 举报

累计签到:22 天
连续签到:1 天
2017-8-17 15:16:42 显示全部楼层
老师我这样写下来之后控制台上并没有显示应该怎么办呢》?
回复 支持 反对

使用道具 举报

累计签到:1070 天
连续签到:3 天
2017-8-20 21:52:24 显示全部楼层
LBB_CQU 发表于 2017-8-17 15:16
老师我这样写下来之后控制台上并没有显示应该怎么办呢》?

下载源码运行看看。
回复 支持 反对

使用道具 举报

尚未签到

2020-2-10 18:25:07 显示全部楼层
谢谢亚非大大分享,现在正在做一个国产数据库的项目,后续有不懂的还要多指教。
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册