解决QT不支持MySQL数据库事务的方案

转载链https://blog.csdn.net/qq_36553707/article/details/109852674

解决QT不支持MySQL数据库事务的方案

一、遇到问题

继上一篇文章《QT之QSql学习》,QT 连接上数据库之后,为了提高代码的执行能力,小编为数据库操作开启了数据库事务。

if(db.transaction()){
    query = new QSqlQuery(db);
    if(query -> exec(sql)){
        db.commit();
        return true;
    }
    db.rollback();
}
return false;

但是执行后却没得到理想的结果,返回值为 false,SQL 语句未被执行,经过 qDebug 输出调试后,结果发现问题出在 db.transaction(), db.transaction() 返回值为false。

二、发现问题

为了验证 QT 是否支持 MySQL 的数据库事务,添加了一下代码进行验证:

qDebug() << db.driver() -> hasFeature(QSqlDriver::Transactions);

结果发现 QT 不支持 MySQL 的数据库事务,在查阅了一系列资料后,最终锁定问题所在,是 MySQL 数据库的驱动和 QT 提供的数据库驱动不一致导致的。

三、解决方案

在 qt 的安装目录下打开以下文件夹:

双击 mysql.pro 文件打开该项目:

双击 mysql.pro 文件,进入配置文件:

对文件进行如下处理后,运行:

a. 将第 6 行代码注释掉:

# 用不上这个语句,不住是会报错,所以需要注释掉
# QMAKE_USE += mysql

b. 在第 1 行代码下添加以下代码:

TARGET = qsqlmysql
# 添加 MySQL 的 include 路径,这里按照自己的安装路径进行修改
INCLUDEPATH +="C:\Program Files (x86)\MySQL\MySQL Server 5.7\include"
# 添加 MySQL 的 libmysql.lib 路径,为驱动的生成提供 lib 文件
LIBS +="C:\Program Files (x86)\MySQL\MySQL Server 5.7\lib\libmysql.lib"

c. 在文件末尾添加以下代码:

# 生成 dll 驱动文件的目录地址,这里将地址设置在 mysql 下的 lib 文件夹中
DESTDIR = ../mysql/lib/

d. 完成前面三步操作后,运行项目会出现一个对话弹框,点击 cannel 按钮取消即可:

又在 qt 的安装目录下打开以下文件夹,发现会多出一个 lib 文件夹(该文件夹为pro配置中的指定文件生成文件夹,生成的驱动文件也在该文件夹中):

双击打开 lib 文件夹,会出现四个文件,复制被框选的两个文件:

在 qt 的安装目录下打开以下文件夹,将刚才复制的两个文件粘贴至该文件夹下,将原有的两个文件给覆盖掉:

再次运行之前写的项目,即可完美解决QT不支持MySQL数据库事务的问题。

//上面已经解决了问题,下面这一部分是顺便复制的

注意:在 Qt5.11.3\5.11.3\msvc2015\lib 路径下的 libmysql.lib 文件与 Qt5.11.3\5.11.3\msvc2015\bin 路径下的 libmysql.dll 文件一定要和当前使用的 MySQL 数据库中包含的文件要匹配(即步骤 4.b 中 lib 路径下的两个文件),否则数据库能连上,但是无法支持数据库事务。(说明:对于 msvc2015 该文件夹名应当和当前开发环境对应)

学习分享,一起成长!接触QT的时间不长,差不多两个月了,有不足之处,欢迎大佬指出来,我会进行更正。有问题可以发送邮件至 mjzhutianxiu@163.com ,不定时上线查收。

————————————————

版权声明:本文为CSDN博主「我是混子我怕谁」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。

原文链接:https://blog.csdn.net/qq_36553707/article/details/109852674

————————————————

版权声明:本文为CSDN博主「我是混子我怕谁」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。

原文链接:https://blog.csdn.net/qq_36553707/article/details/109852674

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值