Qt中使用QSqlDatabase::removeDatabase()的正确方法

如果你用过Qt的QSqlDatabase的话,多半会对下面的警告信息感兴趣:

QSqlDatabasePrivate::removeDatabase: connection 'qt_sql_default_connection' is still in use, all

queries will cease to work.

意思是说,还有某查询引用默认数据库连接"qt_sql_default_connection"。

如果忽略该警告,Qt官方文档里也写了,可能会出现内存泄漏:

Warning: There should be no open queries on the database connection when this function is called,

otherwise a resource leak will occur.

还是不出现这个警告的好。怎么把它弄没了呢?我把一切外围的对象都排除了:仅建立一个连接,打开它,然后关闭连接,调用removeDatabase()。居然还有警告!问题已经锁定在我关闭连接的语句上:

QSqlDatabase::removeDatabase(QSqlDatabase::database().connectionName());

默认连接的名字也是默认的,需要通过connectionName()函数获得。这样写貌似没什么问题,后来调试发现,QSqlDatabase::database()静态函数实际上使默认连接的引用计数+1。上述句子相当于:

QSqlDatabase db = QSqlDatabase::database();//获得实例。
QString name = db.connectionName();//获得默认连接名。
QSqlDatabase::removeDatabase(name);//删除默认连接。

这样,问题就清晰了,db获得了一个引用,此时引用计数为2。在调用removeDatabase()时,db对象并没有被删除,默认连接的引用计数仍为2,于是报告警告信息。

我们只需将其改为:

    QString name;
    {
        name = QSqlDatabase::database().connectionName();
    }//超出作用域,隐含对象QSqlDatabase::database()被删除。
    QSqlDatabase::removeDatabase(name);

问题就解决了!

如果直接打默认连接名的话,代码就简单多了,不过名字不太好打(再说了,万一Qt把默认连接名改了呢!):

QSqlDatabase::removeDatabase("qt_sql_default_connection");//不推荐。

================下面是官方文档摘录================

Warning: There should be no open queries on the database connection when this function is called, otherwise a resource leak will occur.

Example:

 // WRONG
 QSqlDatabase db = QSqlDatabase::database("sales");
 QSqlQuery query("SELECT NAME, DOB FROM EMPLOYEES", db);
 QSqlDatabase::removeDatabase("sales"); // will output a warning
 // "db" is now a dangling invalid database connection,
 // "query" contains an invalid result set

The correct way to do it:

 {
     QSqlDatabase db = QSqlDatabase::database("sales");
     QSqlQuery query("SELECT NAME, DOB FROM EMPLOYEES", db);
 }
 // Both "db" and "query" are destroyed because they are out of scope
 QSqlDatabase::removeDatabase("sales"); // correct
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 这个错误提示表明在尝试删除一个数据库连接时,该连接仍然在使用,因此所有查询都将停止工作。解决此问题的方法是确保在删除连接之前,所有使用该连接的查询都已经完成并关闭。您可以通过检查代码的所有数据库操作来找到哪些查询正在使用该连接,并确保它们已经正确关闭。 ### 回答2: 这是一个数据库连接问题的错误信息。它说明当前连接 '547634241952' 还被使用,所有的查询将停止工作。 通常情况下,当我们使用 QSqlDatabase 进行数据库操作时,需要在完成操作后关闭连接。如果不关闭连接,下次再进行数据库操作时会出现这个错误信息。 要解决这个问题,有以下几种可能的方法: 1. 确保在使用数据库后,调用 QSqlDatabase::removeDatabase 函数来关闭连接。示例代码如下: ```cpp QSqlDatabase db = QSqlDatabase::database("connectionName"); // 执行数据库操作 db.close(); QSqlDatabase::removeDatabase("connectionName"); ``` 这样能够确保在使用数据库后关闭连接,从而避免出现该错误信息。 2. 使用局部作用域。在进行数据库操作时,可以将 QSqlDatabase 对象放置在一个局部作用域内,以确保在操作完成后自动关闭连接。示例代码如下: ```cpp { QSqlDatabase db = QSqlDatabase::database("connectionName"); // 执行数据库操作 } // 在此作用域结束时,QSqlDatabase 对象会自动调用析构函数关闭连接 ``` 3. 检查代码是否有其他地方没有正确关闭连接。可能是因为某些代码逻辑错误导致连接没有正确关闭,需要检查并修正相关代码。 总之,以上是对于错误信息 "QSqlDatabasePrivate::removeDatabase: connection '547634241952' is still in use, all queries will cease to work" 的解释和解决方法。通过关闭连接或修正代码逻辑,可以避免这个错误的发生。 ### 回答3: QSqlDatabasePrivate::removeDatabase: connection '547634241952' is still in use, all queries will cease to work是一个数据库连接仍在使用的警告信息。这意味着在执行此代码之前,还有未完成的数据库查询或事务正在进行。 这个警告通常出现在使用Qt框架的QSqlDatabase类管理数据库连接时。当我们想要关闭一个连接并从连接池删除它时,如果该连接仍然被占用,就会出现这个警告。占用连接的原因可能是还有未完成的数据库查询或事务没有被正确处理。 为了解决这个问题,我们需要确保在关闭和删除数据库连接之前正确处理和释放所有相关的数据库资源。以下是一些可能的解决方案: 1. 确保在关闭连接之前结束所有的查询和事务。可以使用QSqlQuery的finish()方法确保查询完成,并使用QSqlDatabase的commit()或rollback()方法来结束和提交或回滚事务。 2. 确保在关闭连接之前从结果集读取和处理所有查询结果。可以使用QSqlQuery的next()方法遍历结果集,并根据需要读取和处理数据。 3. 确保在关闭连接之前释放所有相关的数据库资源。可以使用QSqlQuery的clear()方法清除查询的结果集,并使用delete关键字明确删除相关的查询对象。 4. 尝试延迟关闭和删除连接,直到确保没有其他代码在使用该连接。可以在连接不再需要时,在适当的时机关闭和删除连接。 总之,解决这个警告需要我们正确处理和释放所有数据库资源,并确保在关闭和删除连接之前没有未完成的查询或事务。这样可以确保代码运行时不会出现问题并继续正常工作。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值