[转帖]如何解除QSqlTableModel和Sqlite数据库的连接_Android, Python及开发编程讨论区_Weblogic技术|Tuxedo技术|中间件技术|Oracle论坛|JAVA论坛|Linux/Unix技术|hadoop论坛_联动北方技术论坛  
网站首页 | 关于我们 | 服务中心 | 经验交流 | 公司荣誉 | 成功案例 | 合作伙伴 | 联系我们 |
联动北方-国内领先的云技术服务提供商
»  游客             当前位置:  论坛首页 »  自由讨论区 »  Android, Python及开发编程讨论区 »
总帖数
1
每页帖数
101/1页1
返回列表
0
发起投票  发起投票 发新帖子
查看: 3784 | 回复: 0   主题: [转帖]如何解除QSqlTableModel和Sqlite数据库的连接        下一篇 
hao.zhang
注册用户
等级:上尉
经验:735
发帖:60
精华:0
注册:2013-10-25
状态:离线
发送短消息息给hao.zhang 加好友    发送短消息息给hao.zhang 发消息
发表于: IP:您无权察看 2013-10-31 15:42:34 | [全部帖] [楼主帖] 楼主

现在是从数据库里查出数据,并显示到控件tableView上,我使用的是QSqlTableModel类,缩减后的代码如下:

C/C++ code



1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19


voidMainWindow::SelectData()

{

QString conn;

{

QSqlDatabase db=QSqlDatabase::addDatabase("QSQLITE");

db.setDatabaseName("test.db");

conn=QSqlDatabase::database().connectionName();

db.open();

QSqlTableModel *model=newQSqlTableModel(this,db);

model->setTable("TestTool");

model->select();

ui->tableView->setModel(model);

ui->tableView->show();

db.close();

qDebug()<<"Congratulations~Selected Successfully~";

}

QSqlDatabase::removeDatabase(conn); 

}


void MainWindow::SelectData()
{
      QString conn;
      {
            QSqlDatabase db=QSqlDatabase::addDatabase("QSQLITE");
            db.setDatabaseName("test.db");
            conn=QSqlDatabase::database().connectionName();
            db.open();
            QSqlTableModel *model=new QSqlTableModel(this,db);
            model->setTable("TestTool");
            model->select();
            ui->tableView->setModel(model);
            ui->tableView->show();
            db.close();
            qDebug()<<"Congratulations~Selected Successfully~";
      }
      QSqlDatabase::removeDatabase(conn);
}


问题来了,每次执行此方法,系统都会报:

QSqlDatabasePrivate::removeDatabase: connection 'qt_sql_default_connection' is still in use, all queries will cease to work.


而如果不用QSqlTableModel类,却不会有这样的错误:

C/C++ code
void MainWindow::SelectData()
{
      QString conn;
      {
            QSqlDatabase db=QSqlDatabase::addDatabase("QSQLITE");
            db.setDatabaseName("test.db");
            conn=QSqlDatabase::database().connectionName();
            db.open();
            QSqlQuery q;
            q.exec("select * from TestTool,TestProgram where TestTool.ToolId=TestProgram.TestId");
            while(q.next())
            {
                  ui->textEdit->append(q.value(1).toString());//append自带换行无需加'\n'
            }
            q.clear();
            db.close();
      }
      QSqlDatabase::removeDatabase(conn); // correct
}


原因可能出在没有解除QSqlTableModel和Sqlite数据库的连接上,小弟刚刚玩Qt,想请问下如何解除QSqlTableModel和Sqlite数据库的连接
北京联动北方科技有限公司

解决办法:



主函数中打开一次数据库连接

C/C++ code
#include <QtGui/QApplication>
#include "mainwindow.h"
#include "main.h"
int main(int argc, char *argv[])
{
      QApplication a(argc, argv);
      ConnectDB();
      MainWindow w;
      w.show();
      return a.exec();
}


其中自定义函数在main.h文件中:

C/C++ code
#ifndef MAIN_H
#define MAIN_H
void ConnectDB()
{
      QSqlDatabase db=QSqlDatabase::addDatabase("QSQLITE");
      db.setDatabaseName("test.db");
}
#endif // MAIN_H


界面类源文件中使用到数据库的地方不再打开数据库:

C/C++ code
void MainWindow::SelectData()
{
      QSqlTableModel *model=new QSqlTableModel(this,db);
      model->setTable("TestTool");
      model->select();
      ui->tableView->setModel(model);
      ui->tableView->show();
      qDebug()<<"Congratulations~Selected Successfully~";
}




赞(0)    操作        顶端 
总帖数
1
每页帖数
101/1页1
返回列表
发新帖子
请输入验证码: 点击刷新验证码
您需要登录后才可以回帖 登录 | 注册
技术讨论