QT 连接数据库的 QSqlDatabase 类 QT 中的 QSqlDatabase 类是连接数据库的核心类,它提供了一个通过数据库连接访问数据库的接口。一个 QSqlDatabase 的实例代表了一个数据库连接,数据库连接通过数据库驱动提供对数据库的访问,数据库驱动继承自 QSqlDriver。 创建数据库连接 ---------------- 为了创建一个数据库连接,需要使用静态方法 addDatabase(),指定驱动或者驱动种类(也就是你要访问什么类型数据库)以及连接名称。一个连接通过它的连接名称识别,不是它连接的数据库名称。你可以有多个连接连到同一个数据库。 例如,下面的代码片段展示了如何创建并打开一个连到 MySQL 数据库的默认连接: ```c QSqlDatabase db = QSqlDatabase::addDatabase("QPSQL"); db.setHostName("acidalia"); db.setDatabaseName("customdb"); db.setUserName("mojito"); db.setPassword("J0a1m8"); bool ok = db.open(); ``` 连接参数 ------------ 一旦创建 QSqlDatabase 对象,就可以通过 setDatabaseName(), setUserName(), setPassword(), setHostName(), setPort(), 还有 setConnectOptions() 来设置连接参数。然后调用 open() 方法打开数据库物理连接。在打开连接之前,连接不可用。 默认连接 ------------ 如果你没有传递连接名称参数给 addDatabase(),那么这个连接将成为默认连接。以后,你可以不用提供连接名称参数直接调用 database() 方法来获得这个默认连接。 例如: ```c QSqlDatabase db = QSqlDatabase::database(); ``` 值类 -------- QSqlDatabase 是一个值类,通过一个 QSqlDatabase 实例对数据库连接做的所有修改会影响到其他 QSqlDatabase 实例中的相同连接。用 cloneDatabase() 可以创建一个与现有连接参数相同但是独立的数据库连接。 多重数据库连接 ----------------- 如果创建多重数据库连接,调用 addDatabase() 时,要为每个连接指定独一无二的名字。调用 database() 方法并传递连接名称来获取该连接。通过调用带有连接名称参数的 removeDatabase() 方法来移除一个连接。 数据表和字段信息 ------------------- 当一个连接被确定以后,你可以调用 tables() 方法来获取数据库的数据表列表,调用 primaryIndex() 方法来获取表的主索引,调用 record() 方法来获取某个表的字段的元信息(比如:字段名)。 事务 -------- 如果驱动支持事务,用 transaction() 开始一个事务,用 commit() 或 rollback() 完成这个事务。用 hasFeature() 询问驱动是否支持事务。注意:当使用事务时,必须在创建查询之前开始事务。 错误处理 ------------ 如果发生错误,lastError() 方法将返回关于该错误的信息。 可用驱动 ------------ 用 drivers() 获取可用的 SQL 驱动名字列表。用 isDriverAvailable() 来检查某个特定的驱动是否可用。如果你创建了自定义驱动,必须调用 registerSqlDriver() 注册它。 QSqlDatabase 类提供了一个灵活且强大的数据库连接接口,能够满足各种数据库应用的需求。
2026-01-16 18:48:40 25KB Access SQL
1
mysql是线程不安全的,mysql不是线程安全的,多线程共用同一个mysql连接是会崩溃的 QT的QSqlDatabase是基于mysql的,所以一样是线程不安全的 现讲明mysql为什么是线程不安全的,以及在多线程环境下如何使用mysql,QSqlDatabase不崩溃的方法.
2022-05-04 01:01:49 25KB mysql QSqlDatabase QT
Qt5.4下连接Mysql,QSqlDatabase: QMYSQL driver not loaded but available-附件资源
2021-11-08 21:41:50 106B
1
QSqlDatabase---mysql插件.zip
2021-07-22 21:03:54 1.03MB mysql qt
1
本文档中记录了QtCreator5.12下使用MVCS2017_64编译器连接Oracle12.2数据库时遇到的问题及解决方法,如: QSqlDatabase: QOCI driver not loaded,包括驱动的添加,数据库的安装配置,经过亲测通过,每一步都配有截图和代码,过程简单却十分详细。
2021-07-13 10:41:29 504KB Qt5.12 Oracle
1
* 数据库连接池特点: * 获取连接时不需要了解连接的名字,连接池内部维护连接的名字 * 支持多线程,保证获取到的连接一定是没有被其他线程正在使用 * 按需创建连接,可以创建多个连接,可以控制连接的数量 * 连接被复用,不是每次都重新创建一个新的连接(连接的创建是一个很消耗资源的过程) * 连接断开了后会自动重连 * 当无可用连接时,获取连接的线程会等待一定时间尝试继续获取,直到取到有效连接或者超时返回一个无效的连接 * 关闭连接很简单
2021-04-14 21:55:10 2.46MB qt5 数据库连接池 QSqlDatabase
1
QT使用QXlsx导出读取sqLite数据库中所有数据到execl的使用示例源码,包括QXlsx库的源码和示例文件,详细见链接https://blog.csdn.net/qq_35554617/article/details/107526577
2021-01-28 03:07:23 451KB Qt QSqlDatabase QXlsx QTabWidget
1
1.sqlTableModeDemo为源码包,不要使用shadowbuild,通知注意mainwindow第26行的发布时和编译时数据库的使用位置; 2.app为独立可运行包,点击即可运行,方便调试与测试。 作者:红胖子/红模仿 QQ:21497936 博客地址:http://blog.csdn.net/qq21497936 本文章地址:http://blog.csdn.net/qq21497936/article/details/78615800
2019-12-21 20:30:24 19.75MB QTableView
1