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

导语 下面十节讲解数据库和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文件的内容如下:

#include <QCoreApplication>
#include <QSqlDatabase>
#include <QDebug>
#include <QSqlQuery>

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支持的数据库仅有两类。如何才能让Qt支持其他的数据库呢,下一节,我们将以现在广为使用的MySql为例,讲解数据库驱动的编译。如果大家想系统的学习Qt数据库部分内容,可以参考《Qt Creator快速入门》的第17章。

涉及到的源码

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
### 回答1: 在Qt,每开一个应用开一个线程数据库是一个可行的选择,但并不是必要的。Qt框架本身提供了很多方便的工具和来处理数据库操作,可以使用单个线程来管理应用程序的多个数据库。 在一个线程可以同时打开和操作多个数据库,这取决于具体的需求和应用程序的设计。例如,如果应用程序需要同时连接多个不同型的数据库,可以在单个线程创建多个数据库连接,每个连接对应一个数据库。 另一方面,如果应用程序的数据库操作比较繁重,可以考虑在单独的线程执行这些操作,以免阻塞主线程并提高应用程序的响应性。这种情况下,可以使用Qt的多线程库来处理数据库操作,并通过信号槽机制与主线程进行通信。 然而,需要注意的是,操作数据库的线程安全性是非常重要的。在同时访问同一个数据库的多个线程需要进行适当的线程同步和互斥处理,以避免数据损坏和冲突。Qt提供了一些线程安全的数据库和接口,可以帮助开发人员在多线程环境安全地进行数据库操作。 综上所述,每开一个应用开一个线程数据库是一种可行的选择,但并非必要。在Qt可以使用单个线程来管理多个数据库连接,并且可以利用多线程库在独立的线程处理数据库操作,以提高应用程序的性能和响应性。同时,需要注意处理线程安全性,以确保数据库操作的正确性和一致性。 ### 回答2: 在Qt,每开一个应用开一个线程数据库是一种错误的理解和使用方式。通常情况下,一个应用程序只需要一个数据库连接,而不是为每个应用开一个线程数据库Qt提供了QtSql模块,用于在应用程序使用数据库。它支持各种数据库,如MySQLSQLite和PostgreSQL等。在使用QtSql时,我们通常会创建一个数据库连接对象,并在整个应用程序共享这个连接对象。在需要使用数据库的地方,我们只需要使用该连接对象执行相应的数据库操作,而不需要为每个应用开启一个线程数据库。 通过共享一个数据库连接对象,我们可以更好地管理数据库连接和资源。这样可以减少数据库连接数,提高数据库的性能和响应速度,并且能够更好地处理并发访问数据库的情况。 在多线程应用Qt还提供了QtConcurrent模块来支持并发和并行操作,包括数据库操作。通过使用QtConcurrent,我们可以将数据库操作放在一个独立的线程进行,以避免阻塞应用程序的主线程。这样可以提升应用程序的响应性能和用户体验。 综上所述,Qt数据库操作方面提供了灵活和高效的解决方案,我们应该根据实际需求来进行合理的数据库连接管理,而不是为每个应用开一个线程数据库。 ### 回答3: 在Qt,通常在每个应用程序只会打开一个数据库连接。这是因为数据库连接是一个高开销的资源,如果每个应用程序都在每次打开时使用不同的线程来创建一个数据库连接,会导致系统资源的浪费,同时也增加了数据库资源的竞争。 Qt数据库模块提供了一种灵活的机制来管理数据库连接,称为"连接池"。连接池允许在应用程序创建和维护一组数据库连接,这些连接可以在应用程序不同的线程共享和重复使用。通过连接池,应用程序可以在需要时从池获取数据库连接,并在使用完毕后将连接归还给池,以供其他线程使用。 在使用连接池的情况下,每个应用程序仍然可以在需要时打开一个新的数据库连接,但不会每次都创建一个新的线程。相反,它会从连接池获取一个可用的数据库连接,并与该线程相关联。这种方式既能满足多线程访问数据库的需求,又能避免不必要的线程和数据库连接的创建。 总之,在Qt,通常会使用连接池来管理和共享数据库连接,以提高系统资源的利用率和并发性。每个应用程序不会为每个线程创建一个新的数据库连接,而是通过连接池来实现线程和连接的关联。这样既满足了多线程访问数据库的需求,又能有效地管理和重用数据库连接。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

世纪隐龙

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值