qt多进程访问一个数据库

q465588824 2011-04-18 11:09:34
多进程通过一个包装的数据库lib同时操作一个数据库xx.db,为何不行。
lib 类testsql中进行连接:
testsql::testsql(const &QString connname)
{
db = QSqlDatabase::addDatabase("QSQLITE", connname);
db.setDatabaseName("/ook.db");
db.open();
query = QSqlQuery(db);
}
A进程
testsql a(QString("a"));
a.createTable(); //新建一个表atable

然后A调用进程B在B中(此时A中没有进行close db)
testsql b(QString("b")); //这里已经设置connection name 为b 不同与a了
b.insertxx(); //针对表atable 插入不成功,似乎什么操作都不成功

问题出在哪呢? 难道A一定要先close(db) ? 有没有其他解决方法?
...全文
468 6 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
6 条回复
切换为时间正序
请发表友善的回复…
发表回复
luochao436 2011-06-03
  • 打赏
  • 举报
回复
正在学习中,围观
AAA20090987 2011-06-03
  • 打赏
  • 举报
回复
[Quote=引用 3 楼 ayan200112 的回复:]

用Singleton设计模式可以很好解决这个问题
[/Quote]

+1
spacexplorer 2011-06-03
  • 打赏
  • 举报
回复
纯接分
shaopengnet 2011-04-18
  • 打赏
  • 举报
回复
把事务加上试试
Escene2021 2011-04-18
  • 打赏
  • 举报
回复
用Singleton设计模式可以很好解决这个问题
q465588824 2011-04-18
  • 打赏
  • 举报
回复
刚刚又试了下
发现单 在A中close(db)还不行 要把类a 释放掉才能让进程B对数据库操作有效。

16,818

社区成员

发帖
与我相关
我的任务
社区描述
Qt 是一个跨平台应用程序框架。通过使用 Qt,您可以一次性开发应用程序和用户界面,然后将其部署到多个桌面和嵌入式操作系统,而无需重复编写源代码。
社区管理员
  • Qt
  • 亭台六七座
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧