Qt数据库简介

1、Qt SQL模块简介

本概述假定您至少具有SQL的基本知识。你应该能够理解简单的SELECT,INSERT,UPDATE,和DELETE语句。尽管QSqlTableModel类提供了不需要浏览SQL即可进行数据库浏览和编辑的接口,但强烈建议您对SQL有基本的了解

QT通过Qt SQL模块提供了对SQL数据库的支持,Qt SQL模块中的API分为三层:驱动层、SQL接口层、用户接口层。

如果要使用Qt SQL模块中的类,需要在工程文件(.pro文件)中添加QT += sql配置。

QT += sql

对应数据库部分的内容,大家可以在帮助中查看SQL Programming关键字。

本文福利,费领取Qt开发学习资料包、技术视频,内容包括(C++语言基础,Qt编程入门,QT信号与槽机制,QT界面开发-图像绘制,QT网络,QT数据库编程,QT项目实战,QSS,OpenCV,Quick模块,面试题等等)↓↓↓↓↓↓见下面↓↓文章底部点击费领取↓↓

1.1、驱动层

​ 驱动层为具体的数据库和SQL接口层之间提供了底层的桥梁,主要类包括QSqlDriver、QSqlDriverCreator、QSqlDriverCreatorBase、QSqlDriverPlugin和QSqlResult。

1.2、SQL接口层

​ SQL接口层提供了对数据库的访问,主要类包括Qt SQL模块中的QSqlDatabase、QSqlQuery、QSqlError、QSqlField、QSqlIndex和QSqlRecord。 QSqlDatabase用来连接数据库,QSqlQuery类用来与数据库实现数据交互。

1.3、用户接口层

​ 用户接口层主要包括Qt SQL模块中的QSqlQueryModel、QSqlTableModel、QSqlRelationalTableModel。用户接口层的类实现了将数据库中的数据链接到窗口部件上,是使用模型/视图框架实现的,是更高层次的抽象,即便不熟悉SQL也可以操作数据库。需要注意的是,在使用用户接口层的类之前必须先实例化QCoreApplication对象。

2. 数据库类

这些类提供对SQL数据库的访问。

 

3、数据库驱动

Qt SQL模块使用数据库驱动和不同的数据库接口进行通信。由于Qt的SQL模块的接口是独立于数据库的,所以所有具体数据库的代码包含在了这些驱动中。QT本身提供了多种数据库驱动,并且可以添加其他数据库驱动。QT提供的数据库驱动源码可以作为编写自定义驱动的模型。

Qt5.12支持的数据库驱动如下: 

4、测试代码

可以使用QSqlDatabase中相关方法测试当前Qt版本默认支持的数据库驱动

测试代码如下:

#include <QCoreApplication>

#include <QSqlDatabase>
#include <QDebug>

int main(int argc, char *argv[])
{
    QCoreApplication a(argc, argv);

    //获取当前Qt支持的驱动列表
    QStringList drivers = QSqlDatabase::drivers();

    foreach (QString driver, drivers)
    {
        qDebug() << driver;
    }

    return a.exec();
}

测试结果如下:

 本文福利,费领取Qt开发学习资料包、技术视频,内容包括(C++语言基础,Qt编程入门,QT信号与槽机制,QT界面开发-图像绘制,QT网络,QT数据库编程,QT项目实战,QSS,OpenCV,Quick模块,面试题等等)↓↓↓↓↓↓见下面↓↓文章底部点击费领取↓↓

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值