添加链接
link管理
链接快照平台
  • 输入网页链接,自动生成快照
  • 标签化管理网页链接

SQLite(sql)是一款开源轻量级的数据库软件,不需要server,可以集成在其他软件中,非常适合嵌入式系统。
Qt5以上版本可以直接使用SQLite(Qt自带驱动)。

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");
    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::database()返回这个连接。
(3)如果这个连接不存在,则进入else分支,需要创建连接,并添加数据库。在else分支第一行,addDatabase()的参数QSQLITE是SQLite对应的驱动名,不能改。而且需要注意的是,addDatabase()的第二个参数被省略了,第二个参数的默认参数就是上面提到的Qt默认连接名称qt_sql_default_connection。如果需要使用自定义的连接名称(如果程序需要处理多个数据库文件的话就会这样),则应该加入第二个参数,例如

database = QSqlDatabase::addDatabase("QSQLITE", "my_sql_connection);

这个时候,如果在另一个地方需要判断my_sql_connection连接是否存在,就应该使用

if(QSqlDatabase::contains("my_sql_connection"))

(4)else分支第二行中,setDatabaseName()的参数是数据库文件名。如果这个数据库不存在,则会在后续操作时自动创建;如果已经存在,则后续的操作会在已有的数据库上进行。
(5)else分支后面两行,设置用户名和密码。用户名,密码都可以随便取,也可以省略。

2.打开数据库

使用open()打开数据库,并判断是否成功。注意,在第一步检查连接是否存在时,如果连接存在,则在返回这个连接的时候,会默认将数据库打开。

if (!database.open())
    qDebug() << "Error: Failed to connect database." << database.lastError();
    // do something

如果打开成功,则进入else分支。对数据库的操作都需要在else分支中进行。

3.关闭数据库

数据库操作完成后,最好关闭。

   database.close();

4.操作数据库

对数据库进行操作需要用到QSqlQuery类,操作前必须定义一个对象。下面举例说明操作方法。操作需要使用SQLite语句,本文中的几个例子会使用几个常用的语句,关于SQLite语句的具体信息请参考SQLite相关资料。

例1:创建表格
创建一个名为student的表格,表格包含三列,第一列是id,第二列是名字,第三列是年龄。

QSqlQuery sql_query;
QString create_sql = "create table student (id int primary key, name varchar(30), age int)";
sql_query.prepare(create_sql);
if(!sql_query.exec())
    qDebug() << "Error: Fail to create table." << sql_query.lastError();
    qDebug() << "Table created!";

代码解释:
(1)第一行定义一个QSqlQuery对象。
(2)第二行是一个QString,其中的内容是SQLite语句。对数据库的操作,都是用SQLite的语句完成的,把这些指令以QString类型,通过prepare函数,保存在QSqlQuery对象中。也可将指令,以QString形式直接写在exec()函数的参数中,例如:

  sql_query.exec("create table student (id int primary key, name varchar(30), age int)");

创建表格语句:create table <table_name> (f1 type1, f2 type2,…);
create table是创建表格的语句,也可用大写CREATE TABLE;student是表格的名称,可以任意取;括号中是表格的格式,上述指令表明,表格中有三列,第一列的名称(表头)是id,这一列储存的数据类型是int,第二列名称是name,数据类型是字符数组,最多有30个字符(和char(30)的区别在于,varchar的实际长度是变化的,而char的长度始终是给定的值),第三列的名称是age,数据类型是int。
如果sql_query.exec()执行成功,则创建表格成功。

例2:插入数据
在刚才创建的表格中,插入一行数据。

QString insert_sql = "insert into student values (?, ?, ?)";
sql_query.prepare(insert_sql);
sql_query.addBindValue(max_id+1);
sql_query.addBindValue("Wang");
sql_query.addBindValue(25);
if(!sql_query.exec())
    qDebug() << sql_query.lastError();
    qDebug() << "inserted Wang!";
if(!sql_query.exec("INSERT INTO student VALUES(3, \"Li\", 23)"))
    qDebug() << sql_query.lastError();
    qDebug() << "inserted Li!";

插入语句:insert into <table_name> values (value1, value2,…);
insert into是插入语句,student是表格名称,values()是要插入的数据。这里,我们插入了2组数据。插入第一组数据的时候,用addBindValue来替代语句中的?,替代的顺序与addBindValue调用的顺序相同。插入第二组数据的时候,则是直接写出完整语句。

例3:更新数据(修改数据)

QString update_sql = "update student set name = :name where id = :id";
sql_query.prepare(update_sql);
sql_query.bindValue(":name", "Qt");
sql_query.bindValue(":id", 1);
if(!sql_query.exec())
    qDebug() << sql_query.lastError();
    qDebug() << "updated!";

语句:update <table_name> set <f1=value1>, <f2=value2>… where ;
更新(修改)的语句是update…set…,其中student是表格名称,name是表头名称(即第二列),:name是待定的变量,where用于确定是哪一组数据,:id也是待定变量。
bindValue(" ", " ")函数用来把语句中的待定变量换成确定值。

例4:查询数据

(1)查询部分数据

QString select_sql = "select id, name from student";
if(!sql_query.exec(select_sql))
    qDebug()<<sql_query.lastError();
    while(sql_query.next())
        int id = sql_query.value(0).toInt();
        QString name = sql_query.value(1).toString();
        qDebug()<<QString("id:%1    name:%2").arg(id).arg(name);

语句select , , … from <table_name>;
select是查询指令; 等等是要查询的变量(即表头),中间用逗号隔开;from …指定表格。
上述语句是说查询student表中的 id 和 name 。执行查询之后,用sql_query.value(int)来获得数据。同样地,value(0)表示第一个数据,即 id,value(1)表示name。注意:value()函数的返回值类型是QVariant,因此要用toInt()等函数转换成特定的类型。

(2)查询全部数据

QString select_all_sql = "select * from student";
sql_query.prepare(select_all_sql);
if(!sql_query.exec())
    qDebug()<<sql_query.lastError();
    while(sql_query.next())
        int id = sql_query.value(0).toInt();
        QString name = sql_query.value(1).toString();
        int age = sql_query.value(2).toInt();
        qDebug()<<QString("id:%1    name:%2    age:%3").arg(id).arg(name).arg(age);

语句select * from <table_name>;
查询所有数据用 * 表示。用while(sql_query.next())用来遍历所有行。同样用value()获得数据。

(3)查询最大id

QString select_max_sql = "select max(id) from student";
int max_id = 0;
sql_query.prepare(select_max_sql);
if(!sql_query.exec())
    qDebug() << sql_query.lastError();
    while(sql_query.next())
        max_id = sql_query.value(0).toInt();
        qDebug() << QString("max id:%1").arg(max_id);

这个就是在语句中用max来获取最大值。

例5:删除与清空

(1)删除一条数据

QString delete_sql = "delete from student where id = ?";
sql_query.prepare(delete_sql);
sql_query.addBindValue(0);
if(!sql_query.exec())
    qDebug()<<sql_query.lastError();
    qDebug()<<"deleted!";

语句delete from <table_name> where =
delete用于删除条目,用where给出限定条件。例如此处是删除 id = 0的条目。

(2)清空表格(删除所有)

QString clear_sql = "delete from student";
sql_query.prepare(clear_sql);
if(!sql_query.exec())
    qDebug() << sql_query.lastError();
    qDebug() << "table cleared";

这里没有用where给出限制,就会删除所有内容。

Qt提供了一种进程内数据库SQLite。它小巧灵活,无须额外安装配置且支持大部分ANSI SQL92标准,是一个轻量级的数据库,概括起来具有以下优点。 SQLite的设计目的是实现嵌入式SQL数据库引擎,它基于纯C语言代码,已经应用在非常广泛的领域内。 SQLite在需要持久存储时可以直接读写硬盘上的数据文件,在无须持久存储时也可以将整个数据库置于内存,两者均不需要额外的服务器端进程,即SQLite是无须独立运行的数据库引擎。 开放源代码,整套代码少于3万行,有良好的注释和90%以上的测试覆盖率。 ,括号里面的字符串是SQLite的命令语句,通过该函数几乎可以运行SQLite的所有命令。使用名称占位符插入记录,这样就可以使用变量,可以同时插入多条记录。int size():获取当前连接下,正在查询的表格的记录数,并不是所有数据库都支。at():返回当前跟踪的表格的索引index,类似于数组的下标。3. 创建多个连接,一个数据库可以创建多个连接,当然一个连接也可以创建多个表格。):获取当前索引下记录某个字段的值,输入参数表示几号字段。不一样,字段的值都是自己输入到表格,字段名也可改为不叫id。 sqlite的创建 db=QtSql.QSqlDatabase.addDatabase("QSQLITE") db.setDatabaseName("mydatabase.db") 在sqlite数据库创建表 create_table_sql = f'''CREATE TABLE IF NOT EXISTS {"我的测试"} ( 使用QSqlDatabase和QSqlQuery实现sqlite3的链接。 首先要在Pro文件加载sql模块,如:QT += sql; 然后使用addDatabase来链接库文件,链接类型有如下: 首先使用创建数据QSqlDatabase对象后,使之成为QqlQuery的句柄。然后使用QSqlQuery的exec来执行数据库语言。 创建数据库 static const char* DBName = "./test.db"; QFileInfo file(DBName); 这篇帖子是我最近学习QTsqlite数据库整理的,之前学的是MySQL应用与Java,现在重新捡起来,小白可以看看,特别简单适合小白。 一、首先看一下布局,形成一个整体的思路 1、添加书获取左边lineEdit的内容 2、删除时通过学号删除。 3、修改是通过学号或者姓名修改 4、查找时上面的文本框输入sql语句(select * from StuInfo where age=22;),然后点击查询,下面的文本框显示结果。 二、数据库内容: 1、字段包括:学号(num)、姓名(name)、年龄(age)、 /编辑策略,所有改变都会在模型进行缓存,直到调用submiAll()或者reverAll函数才生效。通过QT SQL模型类-表格模型实现,通过绑定Table View表格控件后,直接可以修改表格内容,点击提交,自动同步数据库的更新,操作非常方便。......