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

第21篇 数据库(一)Qt数据库应用简介

37
回复
47493
查看
[复制链接]
累计签到:1564 天
连续签到:1 天
来源: 2013-5-13 20:56:39 显示全部楼层 |阅读模式
Qt数据库应用简介
版权声明

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



导语

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



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



目录

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


正文


一、数据库简介

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


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


二、数据库驱动

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


需要说明的是,由于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()函数获取了现在可用的数据库驱动,然后分别进行了输出。运行程序,结果如下图所示。


       可以发现,现在只支持三个数据库。这里要重点提一下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类,将在后面的内容中讲到。运行程序,结果如下图所示。




结语

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



涉及到的源码:



上一篇: 第20篇 2D绘图(十)图形视图框架(下)

下一篇: 第22篇 数据库(二)编译MySQL数据库驱动

返回:系列教程目录   





本帖子中包含更多资源

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

x
回复

使用道具 举报

尚未签到

2013-6-19 08:51:16 显示全部楼层
显示driver  not decleard是怎么回事啊
回复 支持 反对

使用道具 举报

累计签到:1564 天
连续签到:1 天
2013-6-19 16:56:55 显示全部楼层
lblsaber 发表于 2013-6-19 08:51
显示driver  not decleard是怎么回事啊

可以下载后面的源码测试一下。请检查一下系统环境和Qt版本。
回复 支持 反对

使用道具 举报

累计签到:2 天
连续签到:1 天
2013-6-25 13:59:28 显示全部楼层
学习了。QT       += coresql这句core和sql之间应该有个空格吧
回复 支持 反对

使用道具 举报

累计签到:1564 天
连续签到:1 天
2013-6-25 18:08:19 显示全部楼层
tuqiao820 发表于 2013-6-25 13:59
学习了。QT       += coresql这句core和sql之间应该有个空格吧

是啊。本来有的,发布出来以后就消失了,等重新编辑一下。
回复 支持 反对

使用道具 举报

累计签到:75 天
连续签到:1 天
2013-7-5 23:40:27 显示全部楼层
继续学习,楼主您的qt quick教程怎么不见了?
回复 支持 反对

使用道具 举报

累计签到:1564 天
连续签到:1 天
2013-7-6 10:35:06 显示全部楼层
pkgfs 发表于 2013-7-5 23:40
继续学习,楼主您的qt quick教程怎么不见了?

那个可以先在yafeilinux.com下载,也可以参考《Qt及Qt Quick开发实战精解》的相关内容。

这次教程是重新编写的,那部分还没有更新。计划是在Qt 5系列教程里面更新的。但是因为时间原因搁浅了。
回复 支持 反对

使用道具 举报

累计签到:1 天
连续签到:1 天
2013-8-12 13:23:34 显示全部楼层
这是要标准的十五字么,可是还没到

点评

→_→不是贴吧。。  发表于 2013-9-13 16:03
回复 支持 反对

使用道具 举报

累计签到:1 天
连续签到:1 天
2013-8-26 21:08:50 显示全部楼层
为什么下面的两句:
int value0 = query.value(0).toInt();
QString value1 = query.value(1).toString();
出现了这样的报错:
错误:invalid use of incomplete type 'struct QVariant'
错误:forward declaration of 'struct QVariant'
????
我的环境是:Win7+ Qt 4.7.4+Qt Creator2.3.1
回复 支持 反对

使用道具 举报

累计签到:1564 天
连续签到:1 天
2013-8-27 16:01:03 显示全部楼层
linking1987 发表于 2013-8-26 21:08
为什么下面的两句:
int value0 = query.value(0).toInt();
QString value1 = query.value(1).toString();

添加头文件包含
回复 支持 反对

使用道具 举报

累计签到:8 天
连续签到:1 天
2013-9-29 11:30:00 显示全部楼层
一开始显示一个驱动都没有,后来把qt的sqldrivers文件夹复制到debug文件中后,才有显示,不知道为什么,是不是非得这么做?
回复 支持 反对

使用道具 举报

累计签到:1564 天
连续签到:1 天
2013-9-29 23:03:54 显示全部楼层
schades 发表于 2013-9-29 11:30
一开始显示一个驱动都没有,后来把qt的sqldrivers文件夹复制到debug文件中后,才有显示,不知道为什么,是 ...

不是啊,在Qt Creator里面运行应该不用复制的,不过要直接运行exe文件需要复制,就是说发布程序的时候要复制。
回复 支持 反对

使用道具 举报

累计签到:8 天
连续签到:1 天
2013-10-1 14:19:41 显示全部楼层
yafeilinux 发表于 2013-9-29 23:03
不是啊,在Qt Creator里面运行应该不用复制的,不过要直接运行exe文件需要复制,就是说发布程序的时候要 ...

谢谢亚飞老师。后来找到原因了,是因为我以前为了运行exe程序,复制了4.8.4的主要动态链接库文件到system32文件夹,我现在用的是4.8.5的library,library不匹配导致了这个结果。
回复 支持 反对

使用道具 举报

累计签到:1 天
连续签到:1 天
2013-11-8 13:51:29 显示全部楼层
学习中。。。。。。。。。。
回复 支持 反对

使用道具 举报

累计签到:18 天
连续签到:1 天
2014-2-27 14:12:44 显示全部楼层
本帖最后由 拉克丝永恒 于 2014-2-27 14:30 编辑

ubuntu12.04环境下运行程序后terminal什么都没有显示,求解
具体情况:直接从terminal运行工程目录下的sqldrivers,能够出来结果。但是如果在qt中用ctrl+R运行的话,terminal什么都没有显示。而且关掉窗口的话,这个终端进程也没有自动退出
@yafeilinux
回复 支持 反对

使用道具 举报

累计签到:1564 天
连续签到:1 天
2014-2-27 14:48:09 显示全部楼层
schades 发表于 2013-10-1 14:19
谢谢亚飞老师。后来找到原因了,是因为我以前为了运行exe程序,复制了4.8.4的主要动态链接库文件到system ...

是啊,哪个版本Qt编译的程序,就需要哪个版本的dll文件
回复 支持 反对

使用道具 举报

累计签到:1564 天
连续签到:1 天
2014-2-27 14:50:03 显示全部楼层
拉克丝永恒 发表于 2014-2-27 14:12
ubuntu12.04环境下运行程序后terminal什么都没有显示,求解
具体情况:直接从terminal运行工程目录下的sqld ...

那接着学下一节吧,在界面程序中输出就知道什么情况了。
回复 支持 反对

使用道具 举报

累计签到:4 天
连续签到:1 天
2014-5-19 11:13:30 显示全部楼层
yafeilinux 发表于 2013-8-27 16:01
添加头文件包含

要包含哪几个头文件啊
回复 支持 反对

使用道具 举报

累计签到:4 天
连续签到:1 天
2014-5-19 11:42:04 显示全部楼层
ghh244958199 发表于 2014-5-19 11:13
要包含哪几个头文件啊

解决了  添加#include <QVariant.h> 头文件就可以了
回复 支持 反对

使用道具 举报

累计签到:1 天
连续签到:1 天
2014-9-25 17:06:34 显示全部楼层
工作QT 要用到数据库类 太好了 认真看看这篇幅
回复 支持 反对

使用道具 举报

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

公告
可以关注我们的微信公众号yafeilinux_friends获取最新动态,或者加入QQ会员群进行交流:190741849、186601429(已满) 我知道了