正確刪除資料庫連線
如果我們想從資料庫連線列表中刪除一些資料庫連線。我們需要使用 QSqlDatabase::removeDatabase()
,但它是一個靜態函式,它的工作方式有點連線。
// WRONG WAY
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
Qt Document 建議我們的正確方法如下。
{
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