QSqlDatabasePrivate::removeDatabase: connection ‘connection‘ is still in use, all queries will cease

cease:终止

观察这段代码,它会导致上面的警告产生。

    QSqlDatabase database;
    if (QSqlDatabase::contains("connection"))
    {
        database = QSqlDatabase::database("connection");
    }
    else {
        database = QSqlDatabase::addDatabase("QSQLITE", "connection");
        database.setDatabaseName("student.sqlite");
    }
    if (!database.open())
    {
        qDebug() << "Error: Failed to connect database." << database.lastError();
    }
    else {
        QSqlQuery query(database);
        query.exec("select * from menu");
        if (!query.exec())
        {
            qDebug() << "Error:" << query.lastError();
        }
        else {
            while (query.next())
            {
                qDebug() << query.value("name").toString();
            }
            qDebug() << query.size();
        }
        database.close();
    }
    QSqlDatabase::removeDatabase("connection");

末尾调用了QSqlDatabase::removeDatabase("connection");

此方法内部实现中应该调用了QSqlDatabasePrivate::removeDatabase

提示:‘connection’连接仍然在使用,这时候removeDatabase,所有查询都停止工作。

    {
        QSqlDatabase database;
        if (QSqlDatabase::contains("connection"))
        {
            database = QSqlDatabase::database("connection");
        }
        else {
            database = QSqlDatabase::addDatabase("QSQLITE", "connection");
            database.setDatabaseName("identifier.sqlite");
        }
        if (!database.open())
        {
            qDebug() << "Error: Failed to connect database." << database.lastError();
        }
        else {
            QSqlQuery query(database);
            query.exec("select * from kmd_menu");
            if (!query.exec())
            {
                qDebug() << "Error:" << query.lastError();
            }
            else {
                while (query.next())
                {
                    //qDebug() << query.value("name").toString();
                }
                qDebug() << query.size();
            }
            database.close();
        }
    }
    QSqlDatabase::removeDatabase("connection");

这样写就可以了,不弹出上面的提示信息了。

之前在网上查过,有个网友分享的,就是在调用QSqlDatabase::removeDatabase("connection");前析构掉QSqlDatabase对象database。

突然发现我一年前写过一篇类似的文章:

探究QSqlDatabase::removeDatabase_qsqldatabaseprivate::removedatabase: connection 's-CSDN博客

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

lpl还在学习的路上

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值