最近的项目中使用到了访问数据库的功能,平常都是在主线程中访问数据库。使用的非常顺利,出错的话也只是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.prepare("select * from user");
if(query.exec()){
while(query.next()){
..........
}
}
}
子线程:
QSqlDatabase db;
db = QSqlDatabase::addDatabase("QMYSQL","threadDatabase");
..........
if(db.open()){
QSqlQuery query(**db**);
query.prepare("select * from user");
if(query.exec()){
while(query.next()){
..........
}
}
}