1. 程式人生 > >QSqlDatabasePrivate::addDatabase: duplicate connection name 'qt_sql_default_connection'解決辦法

QSqlDatabasePrivate::addDatabase: duplicate connection name 'qt_sql_default_connection'解決辦法

在Qt上使用SQLite的時候,如果第二次使用QSqlDatabase::addDatabase()方式時,就會出現以下錯誤提示:

QSqlDatabasePrivate::addDatabase: duplicate connection name 'qt_sql_default_connection', old connection removed.

解決方法是:先判斷一下這個預設的連線名是否存在,如果不存在才使用addDatabase()方法,如果存在則使用database()方法。

先看一下addDatabase()的原形:

QSqlDatabase QSqlDatabase::addDatabase

(const  & type, const  &connectionName = QLatin1String( defaultConnection )) [static]

解決方法的程式碼:

QSqlDatabase db;
if(QSqlDatabase::contains("qt_sql_default_connection"))
  db = QSqlDatabase::database("qt_sql_default_connection");
else
  db = QSqlDatabase::addDatabase("QSQLITE");

參考連結:http://www.tuicool.com/articles/2Ir26j