Sqlite   发布时间:2022-05-22  发布网站:大佬教程  code.js-code.com
大佬教程收集整理的这篇文章主要介绍了QT SQLite 多数据库操作大全大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。

QT sqlite 多数据库操作大全

一.单数据库模型

一般QT都是把打开一个缺省数据库连接,操作一个数据库连接,但是对sqlite中频率修改容易加锁,因此有一种设计模式是把频率修改的表放在不同的数据库文件中,但这样要修改代码操作数据库部分
通常打开代码 http://developer.nokia.com/community/wiki/CreaTing_an_@R_981_5607@database_in_Qt

bool DatabaseManager::openDB()
    {
    // Find QSlite driver
    db = QsqlDatabase::addDatabase("QsqlitE");

    #ifdef Q_OS_liNUX
    // NOTE: We have to store database fil@R_673_9473@o 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 fil@R_673_9473@o 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::addDatabase(“QsqlitE”); 时会报错

二.同时打开多个数据库

QT本身是支持,只一般写法用得少。成功的代码如下,一般需要一个全局数组来保存这些对象

QString dbname = "base.db"

 QsqlDatabase db ;

 if(QsqlDatabase::contains(dbName)){
        //如已经打开这个数据库,直接调出这个数据连接
      db = QsqlDatabase::database(dbName);
    }else //否则打开这个数据库,注意带上数据库名
      db = QsqlDatabase::addDatabase("QsqlitE",dbName);

三.相关数据库的类调用

因为引入多数据库,相应类调用都要引入数据库连接对象。

3.1 Qsqlquery

sql 查询类,可以执行各种sql指令。缺省使用方法是

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 类

这个也是常用的类,与各种控件配合相当好用,

它的指定数据库连接言式是在调用setquery时,

QsqlDatabase db ; //已经打开数据库对象

Qsqlquerymodel * sqlmodel = new Qsqlquerymodel();
   sqlmodel->setquery("SELEct * FROM table",db);

大佬总结

以上是大佬教程为你收集整理的QT SQLite 多数据库操作大全全部内容,希望文章能够帮你解决QT SQLite 多数据库操作大全所遇到的程序开发问题。

如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。
标签: