QT sqlite 多数据库操作大全
一.单数据库模型
一般QT都是把打开一个缺省数据库连接,操作一个数据库连接,但是对sqlite中频率修改容易加锁,因此有一种设计模式是把频率修改的表放在不同的数据库文件中,但这样要修改代码操作数据库部分
通常打开代码 http://developer.nokia.com/community/wiki/Creating_an_SQLite_database_in_Qt
bool DatabaseManager::openDB()
{
// Find QSLite driver
db = QsqlDatabase::addDatabase("QsqlITE");
#ifdef Q_OS_LINUX
// NOTE: We have to store database file into user home folder in Linux
QString path(QDir::home().path());
path.append(QDir::separator()).append("my.db.sqlite");
path = QDir::toNativeSeparators(path);
db.setDatabaseName(path);
#else
// NOTE: File exists in the application private folder,in Symbian Qt implementation
db.setDatabaseName("my.db.sqlite");
#endif
// Open databasee
return db.open();
}
QsqlError DatabaseManager::lastError()
{
// If opening database has Failed user can ask
// error description by QsqlError::text()
return db.lastError();
}
bool DatabaseManager::deleteDB()
{
// Close database
db.close();
#ifdef Q_OS_LINUX
// NOTE: We have to store database file into user home folder in Linux
QString path(QDir::home().path());
path.append(QDir::separator()).append("my.db.sqlite");
path = QDir::toNativeSeparators(path);
return QFile::remove(path);
#else
// Remove created database binary file
return QFile::remove("my.db.sqlite");
#endif
}
这是最关键是两步
QsqlDatabase db = QsqlDatabase::addDatabase(“QsqlITE”); #打开数据库
db.setDatabaseName(“my.db.sqlite”); #指定数据库文件
但是重复调用QsqlDatabase::addDatabase(“QsqlITE”); 时会报错
QsqlDatabasePrivate::addDatabase: duplicate connection name ‘qt_sql_default_connection’,old connection removed.
二.同时打开多个数据库
QT本身是支持,只一般写法用得少。成功的代码如下,一般需要一个全局数组来保存这些对象
QString dbName = "base.db"
QsqlDatabase db ;
if(QsqlDatabase::contains(dbName)){
//如已经打开这个数据库,直接调出这个数据连接
db = QsqlDatabase::database(dbName);
}else //否则打开这个数据库,注意带上数据库名
db = QsqlDatabase::addDatabase("QsqlITE",dbName);
三.相关数据库的类调用
3.1 QsqlQuery
QsqlQuery query();
query.exec("select * from table1");
但这种情况,在多数据库模式会报错,提示,>QsqlQuery::exec: database not open
其实这是调用缺省的数据连接又未打开这个造成,可以在初始化是直接数据库对象
QsqlDatabase db ; //已经打开数据库对象
QsqlQuery query(db);
query.exec("select * from table1");
3.2 QsqlQueryModel 类
这个也是常用的类,与各种控件配合相当好用,
QsqlDatabase db ; //已经打开数据库对象
QsqlQueryModel * sqlModel = new QsqlQueryModel();
sqlModel->setQuery("select * from table",db);