Qt 数据库应用(1)-分层

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

Qt 数据库应用(1)-分层_第1张图片

驱动层为具体的数据库和SQL接口层之间提供了底层的桥梁;

SQL接口层提供了对数据库的访问,其中的QSqlDatabase类用来创建连接,QSqlQuery类可以使用SQL语句来实现与数据库交互,其他几个类对该层提供了支持;

用户接口层的几个类实现了将数据库中的数据链接到窗口部件上,这些类是使用模型/视图框架实现的,它们是更高层次的抽象,即便不熟悉SQL也可以操作数据库。如果要使用QtSql模块中的这些类,需要在项目文件(.pro文件)中添加QT += sql这一行代码。

使用用户接口层和SQL接口层都可以完成数据库操作,推荐使用用户接口层来进行设计,如果选用QSqlQuery类进行操作,需要对数据库SQL语法进行一层封装。

因此,此处所说的主要区别在于使用SQL语法进行操作,还是使用表格进行操作,即QSqlQuery和用户接口层其他类的区别

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

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

QT       += core sql

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

3.将main.cpp文件的内容更改如下:

#include 
#include 
#include 
#include 
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();
}

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

#include 
#include 
#include 
#include 

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

    //添加数据库驱动
    QSqlDatabase db = QSqlDatabase::addDatabase("QSQLITE");
    //设置数据库名称
    db.setDatabaseName(":memory:");
    //打开数据库
    if(!db.open())
    {
        return false;
    }

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

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

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

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

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

    return a.exec();
}

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

你可能感兴趣的:(QT,qt,c++)