QT操作数据库

时间记录:2024/1/20

一、QT+mysql配置

1.1 环境介绍

Qt Creator5.12.7+Mysql5.5.28+Windows10操作系统

1.2 编译mysql-driver

(1)查看可用的sql-driver

cpp 复制代码
qDebug() << QSqlDatabase::drivers();

输出:("QSQLITE", "QODBC", "QODBC3", "QPSQL", "QPSQL7"),默认QT5.12.7 没有mysql的驱动

(2)编译libmysql.dlllibmysql.lib 文件

1.找到QT源码src目录的qtbase/src/plugins/sqldrivers/mysql目录,打开mysql.pro文件,在QMAKE_USE += mysql前边加"#"号注释此行,然后添加以下代码,mysql的安装路径要做对应的替换

cpp 复制代码
LIBS += -LD:/apps/MYSQL/lib -llibmysql

INCLUDEPATH += D:/apps/MYSQL/include

DEPENDPATH += D:/apps/MYSQL/include

2.打开qsqldriverbase.pri 文件,将include(/qtsqldrivers-config.pri)这一行注释掉

3.编译pro文件生成qsqlmysql.dllsqlmysqld.dll 文件,双击pro文件打开项目,选择套件编译即可

4.将生成的qsqlmysql.dllqsqlmysqld.dll 文件复制到QT相应套件的"\plugins\sqldrivers "路径下

5.编写代码,将mysql 安装目录下的libmysql.dll 文件复制到项目的应用程序同级目录下或者复制到编译套件的bin目录下,发布应用程序时同样需要复制此文件到应用程序同级目录下

二、QT命令行编译项目

(1)调出套件命令行,切换到项目pro文件的目录,输入命令"qmake -project"生成pro文件

(2)打开pro文件,添加使用到的QT模块,然后命令行输入命令"qmake xxx.pro -spec win32-g++ "CONFIG+=debug" "CONFIG+=qml_debug""或者"qmake xxx.pro"生成makefile文件

(3)使用命令"mingw32-make -f Makefile.Debug"来执行make命令生成可执行程序

三、QT连接数据库

(1)在pro文件中添加sql 模块

(2)创建QDatabase 数据库配置对象

2.1 使用静态方法addDatabase 配置数据库驱动"QMYSQL "或"QSQLITE "

2.2 使用方法setHostName 配置mysql数据库的服务器IP地址

2.3 使用方法setPort 配置mysql数据库的服务器端口号

2.4 使用方法setDatabaseName 配置要连接的数据库名称

2.5 使用方法setUserName 配置登录mysql服务器的用户名

2.6 使用方法setPassword 配置登录mysql服务器的密码

(3)使用QDatabase 类的方法open 打开数据库

(4)编写sql语句,然后使用QSqlQuery 类的exec 方法执行固定语句

(5)获取查询结果使用QSqlQuery 类的next 方法判断是否还有下一行数据,判断之后会自动下移一行,value 方法获取行内的数据,传入数字则获取到此行某一列数据,传入字符串则根据获取到此行对应键名的值

(6)批处理操作,根据可变参进行数据处理

6.1 使用QSqlQuery 类的prepare 方法编写sql语句,参数使用?表示,然后使用addBindValue 方法为?绑定值,最后使用execBatch 方法执行sql语句

6.2 使用QSqlQuery 类的prepare 函数编写sql语句,sql语句中的值使用":别名 "代替,然后使用bindValue 函数为别名绑定值,绑定完毕值以后便可以使用execBatch函数进行批处理操作

(7)使用QDatabase 类的close方法关闭数据库连接

四、简单的一些sql语句

(1)创建表

cpp 复制代码
create table if not exists 表名(键名1 键数据类型1,键名2 键数据类型2...);
示例:
create table if not exists user(id int primary key auto_increment,username varchar(20),password varchar(20));  

(2)添加数据

cpp 复制代码
insert into 表名(键名1...) values(值1...);

(3)删除数据

cpp 复制代码
delete from 表名 where 删除条件;
示例:
delete from user where id=2;

(4)修改数据

cpp 复制代码
update 表名 set 键=值,键=值 where 修改条件
示例:
update user set username='admin',password='123456' where id = 1;

(5)查询数据

cpp 复制代码
select 键名 from 表名;
示例1:查询全部数据
select * from user;
示例2:查询指定键的数据
select username as u,password as p from user;
相关推荐
weixin_307779135 分钟前
使用C#实现从Hive的CREATE TABLE语句中提取分区字段名和数据类型
开发语言·数据仓库·hive·c#
Xiaok101813 分钟前
解决 Hugging Face SentenceTransformer 下载失败的完整指南:ProxyError、SSLError与手动下载方案
开发语言·神经网络·php
绿草在线15 分钟前
Mock.js虚拟接口
开发语言·javascript·ecmascript
go_bai26 分钟前
Linux环境基础开发工具——(2)vim
linux·开发语言·经验分享·笔记·vim·学习方法
小郝 小郝27 分钟前
【C语言】strstr查找字符串函数
c语言·开发语言
信徒_31 分钟前
Mysql 在什么样的情况下会产生死锁?
android·数据库·mysql
yinhezhanshen33 分钟前
理解rust里面的copy和clone
开发语言·后端·rust
Zhichao_9733 分钟前
【UE5 C++课程系列笔记】33——商业化Json读写
c++·ue5
Jtti1 小时前
PHP在Debian环境上的并发处理能力如何
开发语言·debian·php
时光追逐者1 小时前
在 Blazor 中使用 Chart.js 快速创建数据可视化图表
开发语言·javascript·信息可视化·c#·.net·blazor