新浪微博
腾讯微博
会员列表
统计排行
基本信息
到访IP统计
管理团队
管理统计
在线会员
会员排行
版块排行
帖子排行
标签排行
帮助
下拉
用户名
电子邮箱
用户名
密 码
记住登录
登录
找回密码
注册
快捷通道
关闭
您还没有登录,快捷通道只有在登录后才能使用。
立即登录
还没有帐号? 赶紧
注册一个
首页
论坛
Qt下载
作品展
群组
个人中心
捐赠、管理与开发
邮件订阅
帖子
文章
日志
用户
版块
群组
帖子
搜索
QTCN开发网
>
Qt基础编程
>
Qt5.12.6 数据库跨线程访问失败
发帖
回复
返回列表
新帖
1758
阅读
2
回复
[提问]
Qt5.12.6 数据库跨线程访问失败
[复制链接]
上一主题
下一主题
离线
yyzq
UID:155340
注册时间
2014-08-28
最后登录
2020-08-18
在线时间
142小时
发帖
37
搜Ta的帖子
精华
0
金钱
400
威望
48
贡献值
1
好评度
38
访问TA的空间
加好友
用道具
新手上路
关闭
个人中心可以申请新版勋章哦
立即申请
知道了
加关注
发消息
只看楼主
倒序阅读
楼主
发表于: 2020-06-09
问题
描述:
原先的代码使用Qt5.4 msvc编译32位程序,
数据
库
的初始化放在
线程
访问是在
其他
线程 正常
没有
问题
同样的代码升级到Qt5.12.6编译64位,初始化可以成功 访问失败 提示drive not loaded
代码如下:
复制代码
bool BTDatabaseCtl::initDB(const QString &dbName, const QString &password)
{
[color=#ff0000]//--- 线程中初始化[/color]
mMutex.lock();
bool flag = false;
if (mDriver == nullptr)
{
mDriver = new ZSQLiteCipherDriver();
}
else
{
mMutex.unlock();
return true;
}
mDBName = dbName;
mPassword = password;
mConnectionName = BTAppHelper::creatUid();
QSqlDatabase innerDB = QSqlDatabase::addDatabase(mDriver, mConnectionName);
switch (openDB(innerDB, dbName, password))
{
case -2:
LOG_ERROR() << "Open database failed." << dbName;
break;
case -1:
LOG_ERROR() << "Create database failed." << dbName;
break;
case 0:
LOG_ERROR() << "Incorrect password/not database file." << dbName;
break;
case 1:
LOG_DEBUG() << "Create database succeeded." << dbName;
flag = true;
break;
case 2:
LOG_DEBUG() << "Open database succeeded." << dbName;
flag = true;
break;
}
mMutex.unlock();
return flag;
}
复制代码
int BTDatabaseCtl::openDB(QSqlDatabase &db, const QString &dbName, const QString &password)
{
QFile file(dbName);
bool isDbFileExists = file.exists() && (file.size() > 0);
db.setDatabaseName(dbName);
db.setPassword(password);
if (!db.open())
{
return isDbFileExists ? -2 : -1;
}
if (isDbFileExists && !isDbDecrypted(db))
{
db.close();
return 0;
}
return isDbFileExists ? 2 : 1;
}
复制代码
QSqlDatabase BTDatabaseCtl::getEncryptedDB()
{
mMutex.lock();
[color=#ff0000]// 数据库连接名是存在的[/color]
if (QSqlDatabase::contains(mConnectionName))
{
[color=#ff0000]// 但是此处获取失败 db.isValid()返回false[/color]
QSqlDatabase db = QSqlDatabase::database(mConnectionName);
if (db.isOpen())
{
mMutex.unlock();
return db;
}
db.setDatabaseName(mDBName);
db.setPassword(mPassword);
if (!db.open())
{
LOG_ERROR() << "Open database failed:" << mDBName;
}
mMutex.unlock();
return db;
}
QSqlDatabase innerDB = QSqlDatabase::addDatabase(mDriver, mConnectionName);
innerDB.setDatabaseName(mDBName);
innerDB.setPassword(mPassword);
if (!innerDB.open())
{
LOG_ERROR() << "Open database failed:" << mDBName;
}
mMutex.unlock();
return innerDB;
}
共
条评分
回复
举报
分享到
淘江湖
新浪
QQ微博
QQ空间
开心
人人
豆瓣
网易微博
百度
鲜果
白社会
飞信
离线
75233109
UID:202029
注册时间
2020-04-18
最后登录
2024-04-14
在线时间
1小时
发帖
2
搜Ta的帖子
精华
0
金钱
30
威望
32
贡献值
0
好评度
2
访问TA的空间
加好友
用道具
新手上路
加关注
发消息
只看该作者
1楼
发表于: 2020-06-09
不是版本问题,
Qt的数据库本来就不支持跨线程访问
共
条评分
回复
举报
离线
yyzq
UID:155340
注册时间
2014-08-28
最后登录
2020-08-18
在线时间
142小时
发帖
37
搜Ta的帖子
精华
0
金钱
400
威望
48
贡献值
1
好评度
38
访问TA的空间
加好友
用道具
新手上路
加关注
发消息
只看该作者
2楼
发表于: 2020-06-10
回 75233109 的帖子
75233109
:
不是版本问题,
Qt的数据库本来就不支持跨线程访问
(2020-06-09 18:55)
谢谢,是的 在使用的线程open就可以了
共
条评分
回复
举报
发帖
回复
返回列表
http://www.qtcn.org/bbs
访问内容超出本站范围,不能确定是否安全
继续访问
取消访问
快速回复
限100 字节
您目前还是游客,请
登录
或
注册
进入高级模式
文字颜色
发 布
回复后跳转到最后一页
上一个
下一个
关闭
补充发布信息
验证码:
发 布
隐藏
快速跳转
站务及资讯
网站公告
新闻资讯
Qt官方发布
网站管理
Qt应用及资源
Qt 作品展
Qt代码秀
Qt应用版
Qt技术讨论区
Qt安装与发布
Qt中文处理
Qt基础编程
Qt QML开发
Qt嵌入式开发
Qt移动平台开发
其它技术开发讨论区
Qt图书专区
《C++ GUI Qt 4编程》(第2版)专栏
《Qt高级编程》专栏
《零基础学Qt4编程》专栏
《Qt设计模式》(第2版) 图书专栏
Python Qt GUI快速编程
Qt项目开发区
天池项目
Qt开放平台开发库
Qt版百度云笔记
机械CAD
Qt文档计划
QTCN网站系统开发
扇贝词典
非活跃项目区
社区中心
帖子回收站(Trash)
招聘、求职、供求、广告等
休闲娱乐
关闭
关闭
选中
1
篇
全选