介绍
Sqlite 数据库作为 Qt 项目开发中经常使用的一个轻量级的数据库,不需要server,可以说是兼容性相对比较好的数据库之一。其可以集成在其他软件中,非常适合嵌入式系统。本文为大家介绍了Qt操作SQLite数据库的具体方法,希望对大家有所帮助。
优点
- SQLite 的设计目的是嵌入式 SQL 数据库引擎,它基于纯C语言代码,已经应用于非常广泛的领域内。
- SQLite 在需要长时间存储时可以直接读取硬盘上的数据文件(.db),在无须长时间存储时也可以将整个数据库置于内存中,两者均不需要额外的服务器端进程,即 SQLite 是无须独立运行的数据库引擎。
- 源代码开源,你可以用于任何用途,包括出售它。
- 零配置 – 无需安装和管理配置。
- 不需要配置,不需要安装,也不需要管理员。
- 同一个数据文件可以在不同机器上使用,可以在不同字节序的机器间自由共享。
- 支持多种开发语言,C, C++, PHP, Perl, Java, C#,Python, Ruby等。
用法
1 准备
- 引入SQL模块
在Qt项目文件(.pro文件)中,加入SQL模块:
QT += sql
- 引用头文件
在需要使用SQL的类定义中,引用相关头文件。例如:
#include <QSqlDatabase>
#include <QSqlError>
#include <QSqlQuery>
2 使用
1. 建立数据库
检查连接、添加数据库驱动、设置数据库名称、数据库登录用户名、密码。
QSqlDatabase database;
if (QSqlDatabase::contains("qt_sql_default_connection"))
{
database = QSqlDatabase::database("qt_sql_default_connection");
}
else
{
database = QSqlDatabase::addDatabase("QSQLITE");
database.setDatabaseName("MyDataBase.db");
database.setUserName("XingYeZhiXia");
database.setPassword("123456");
}
上述代码解释:
(1)第一行中,建立了一个QSqlDatabase
对象,后续的操作要使用这个对象。
(2)if
语句用来检查指定的连接(connection)是否存在。这里指定的连接名称(connection name)是qt_sql_default_connection
,这是Qt默认连接名称。实际使用时,这个名称可以任意取。如果判断此连接已经存在,那么QSqlDatabase::contains()
函数返回true。此时,进入第一个分支,QSqlDatabase: