请问在QThread环境下QSqlDatabase执行发生异常

stivenjia 2010-12-09 06:40:28
具体是在执行QSqlDatabase::addDatabase函数时候出现异常提示,该行代码运行在QThread环境下

...全文
192 3 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
3 条回复
切换为时间正序
请发表友善的回复…
发表回复
stivenjia 2010-12-10
  • 打赏
  • 举报
回复
tmd又出现一个鸟错误
在一个线程内向另一个线程对象发送一个自定义事件,结果发生错误了

template <typename ForwardIterator>
Q_OUTOFLINE_TEMPLATE void qDeleteAll(ForwardIterator begin, ForwardIterator end)
{
while (begin != end) {
delete *begin; //说是这这个节点0了
++begin;
}
}
nnd,这东西是那么发过去的
QApplication::postEvent(m_lpDataService,new CUpdateDataService(lpData,TLS_CMD::CONNECT_DB));
另一个线程对象的custerEvent也响应了,但是执行过后就出现上述错误
stivenjia 2010-12-10
  • 打赏
  • 举报
回复
QSqlDatabase::database搞定
QSqlDatabase::addDatabase就不可以,貌似这个函数需要全局表什么的!

QT help说了
“A connection can only be used from within the thread that created it. Moving connections between threads or creating queries from a different thread is not supported. ”

QSqlDatabase的作用域也只能在一个县城内,所以这里将一个QSqlDatabase对象设计在一个thread内,该thread负责该对象的初始化,释放等操作。
dext 2010-12-10
  • 打赏
  • 举报
回复
可能会有问题吧,没有试过,为什要在 线程中 加载驱动呢?
可以初始化的时候加载,线程中连接访问啊?

16,818

社区成员

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

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