QT 中 SQLite 使用方法

一、pro文件中包含:

cpp 复制代码
QT       += ... sql

二、SQLite 使用要包含的头文件:

cpp 复制代码
#include <QSqlDatabase> // 数据库驱动
#include <QSqlQuery> // 数据库执行语句
#include <QSqlError> // 数据库日志

三、数据库创建

cpp 复制代码
QSqlDatabase database; // 建立了一个QSqlDatabase对象

QSqlDatabase::contains(connection name); // 查看对应连接是否存在(true/false)

database = QSqlDatabase::database(connection name); // 返回对应连接

QSqlDatabase::addDatabase("QSQLITE", connection name); // 创建连接并添加数据库

database.setDatabaseName("MyDataBase.db"); // 指定数据库名称

database.setUserName(id); // 设置用户名(可不要)

database.setPassword(pwd); // 设置密码(可不要)

database.open(); // 使用open()打开数据库

database.close(); // 使用close()关闭数据库

四、数据库使用

1、创建

创建数据库方法:create table <table_name> (f1 type1, f2 type2,...);

基本格式:

cpp 复制代码
QSqlQuery sqlQuery; // 定义 QSqlQuery 对象

QString createsql = "数据库操作语句"; // 数据库执行语句

sqlQuery.prepare(createsql); // 将语句保存到 sqlQuery 中

sqlQuery.exec() // 执行该语句  或者可以直接写成 sqlQuery.exec(createsql)

例如创建一个students表,标题分别为id、name、score、class:

cpp 复制代码
query.exec("CREATE TABLE students ("
                   "id INTEGER PRIMARY KEY AUTOINCREMENT, "
                   "name VARCHAR(40) NOT NULL, "
                   " score INTEGER NOT NULL, "
                   "class VARCHAR(40) NOT NULL)");

AUTOINCREMENT:表示该列为整数递增,如果为空时则自动填入1,然后在下面的每一行都会自动+1,

PRIMARY KEY:则表示该列作为列表的主键,通过它可以轻易地获取某一行数据

INTEGER:表示该列为带符号的整数

VARCHAR(40):表示该列为可变长字符串,默认只能存储英文和数字或者utf-8,最多存储40个字节.

NOT NULL:表示该列的内容不为空

2、插入

插入语句:insert into <table_name> (table1, table2,...) values (value1, value2,...);

插入数据的三种格式:

cpp 复制代码
// 1
QString insert_sql = "insert into student (id, name, age) values (3, \"Wang\", 25)";
sql_query.exec(insert_sql);

// 2
QString insert_sql = QString("INSERT INTO student VALUES ('%1', '%2', '%3')").arg(3).arg(Wang).arg(25);
sql_query.exec(insert_sql);

// 3
QString insert_sql = QString("INSERT INTO student VALUES (:id :name :age)");
sql_query.bindValue(":id",3); // 使用后面的内容对前面""中的内容进行替换
sql_query.bindValue(":name","Wang");
sql_query.bindValue(":age",25);
query.exec();

3、查询

查询语句:select , , ... from <table_name>;

查询格式:

cpp 复制代码
QString select_sql = "select id, name from student";
if(!sql_query.exec(select_sql))
{
    qDebug()<<sql_query.lastError();
}
else
{
    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);
    }
}

查询某一范围:

cpp 复制代码
// 查询成绩在60~80之间的数据
select * from students where score >= 60 and score <= 80

查询指定信息:

cpp 复制代码
// 查询用户名和密码是否存在
QString sql=QString("select * from user where username='%1' and password='%2'").arg(username).arg(password);

查询指定字符:

cpp 复制代码
// GLOB表示通配符,匹配班级带有"3-3"的名字
SELECT * FROM students WHERE class GLOB '*3-3*'

4、删除

删除语句:delete from <table_name> where =

删除格式:

cpp 复制代码
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();
}
else
{
    qDebug()<<"deleted!";
}

query.exec("DELETE FROM students"); // 删除students表里所有内容
相关推荐
LilySesy6 分钟前
ABAP+在select的时候,可以A=B A=C B=C这样子JOIN吗?
数据库·sql·ai·excel·sap·abap
feiyangqingyun12 分钟前
Qt/C++编写GB28181服务/前后端分离/定义一套交互协议/视频点播/录像回放和控制/警情通知
c++·qt·交互
升鲜宝供应链及收银系统源代码服务32 分钟前
升鲜宝生鲜配送供应链管理系统--- 《多语言商品查询优化方案(Redis + 翻译表 + 模糊匹配)》
java·数据库·redis·bootstrap·供应链系统·生鲜配送·生鲜配送源代码
JH307334 分钟前
Redis 中被忽视的“键过期策略”与内存回收机制
数据库·redis·缓存
Microsoft Word35 分钟前
Redis常见面试题
数据库·redis·缓存
lingggggaaaa35 分钟前
小迪安全v2023学习笔记(一百四十五讲)—— Webshell篇&魔改冰蝎&打乱特征指纹&新增加密协议&过后门查杀&过流量识别
笔记·学习·安全·魔改冰蝎·免杀对抗·免杀技术
bing.shao40 分钟前
mongodb与redis在聊天场景中的选择
数据库·redis·mongodb
dudke40 分钟前
c#实现redis的调用与基础类
数据库·redis·缓存
苦学编程的谢41 分钟前
Redis_7_hash
数据库·redis·哈希算法
许愿OvO42 分钟前
MySQL-索引
数据库·mysql