(1)解决:QT多线程访问数据库报QMYSQLResult::cleanUp :unable to free statement handle

1 篇文章 0 订阅
1 篇文章 0 订阅
最近的项目中使用到了访问数据库的功能,平常都是在主线程中访问数据库。使用的非常顺利,出错的话也只是bindValue的占位符顺序不对。而项目中有线程的问题,而有时候要让子线程自己去查询数据库获得结果(主要是考虑到查询结果之后有大量的计算功能)。因此在项目中直接套用了传统的方法,本来以为很顺利的完成。但是问题来咯!!在一个函数中,主线程先去简单的查询数据,然后紧接着调用子线程去查询数据、计算。但是在多次执行或者将程序来回切换几次之后。就输出了***QMYSQLResult::cleanUp :unable to free statement handle***的提示信息,紧接着就无法访问数据库了。
在论坛里求助了之后,@公孙二狗和@foxyz回答了问题,说是一个QSqlDatabase(connection name一样)的对象只可以在一个线程中访问,并且在QT帮助文档**Thread-Support in Qt Modules**的第一个提到的便是此注意事项。于是便着手写测试的例子。现将解决方法和大家分享一下(如有错误还请指教)
    主线程:
    QSqlDatabase db;
    db = QSqlDatabase::addDatabase("QMYSQL","mainDatabase");
    ..........
    if(db.open()){
        QSqlQuery query(db);  //此时在创建query对象时,要将上面自定义connectionName的database传入
        query.prepare("select * from user");
        if(query.exec()){
            while(query.next()){
               ..........
            }
        }
    }
子线程:
    QSqlDatabase db;
    db = QSqlDatabase::addDatabase("QMYSQL","threadDatabase");
    ..........
    if(db.open()){
        QSqlQuery query(**db**);  //此时在创建query对象时,要将上面自定义connectionName的database传入
        query.prepare("select * from user");
        if(query.exec()){
            while(query.next()){
               ..........
            }
        }
    }
  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值