一般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);
因为引入多数据库,相应类调用都要引入数据库连接对象。
sql 查询类,可以执行各种Sql指令。缺省使用方法是
  QSqlQuery query();
  query.exec("select * from table1");
但这种情况,在多数据库模式会报错,提示,>QSqlQuery::exec: database not open
其实这是调用缺省的数据连接又未打开这个造成,可以在初始化是直接数据库对象
QSqlDatabase db ; //已经打开数据库对象
  QSqlQuery query(db);
  query.exec("select * from table1");
这个也是常用的类,与各种控件配合相当好用,
它的指定数据库连接言式是在调用setQuery时,
QSqlDatabase db ; //已经打开数据库对象
QSqlQueryModel * sqlModel = new QSqlQueryModel();
   sqlModel->setQuery("select * from table",db);原文地址:http://blog.csdn.net/work4blue/article/details/43908205