QT读写Sqlite

    科技2025-07-13  6

    在.pro文件中添加QT += sql 执行qmake QT对一些基本的数据库的访问封装,可谓是极大的方便的我们开发人员,现在我们就来说下QT对Sqlite这个数据库的读写,Sqlite是一个比较小型的本地数据库,对于保存一些软件配置参数或量不是很大的数据是相当的方便,Qt本身已经自带了Sqlite的驱动,直接使用相关的类库即可,这篇我们主要来说明QT访问Sqlite数据库的三种方式(即使用三种类库去访问),分别为QSqlQuery、QSqlQueryModel、QSqlTableModel,对于这三种类库,可看为一个比一个上层,也就是封装的更厉害,甚至第三种QSqlTableModel,根本就不需要开发者懂SQL语言,也能操作Sqlite数据库。

    1、首先使用QSqlQuery来访问 我们先要在工程中包含与数据库相关的几个头文件

    #include <QtWidgets/QApplication> #include <QCoreApplication> #include <QDebug> #include <QtSql/QSqlDatabase> #include <QtSql/QSqlQuery> #include <QtSql/QSqlRecord> typedef struct _testInfo //假定数据库存储内容 { QString UsreName; QString IP; QString Port; QString PassWord; QString Type; }testInfo; int main(int argc, char *argv[]) { QApplication a(argc, argv); QVector<testInfo> infoVect; //testInfo向量,用于存储数据库查询到的数据 QSqlDatabase db = QSqlDatabase::addDatabase("QSQLITE"); db.setDatabaseName(QApplication::applicationDirPath() + "/CONFIG/" + "CONFIG.db"); if (!db.open()) { return 0; } /**************************使用QSqlQuery操作数据库**************************/ QSqlQuery query; //执行操作类对象 //查询数据 query.prepare("SELECT * FROM T_USER_MANAGE"); query.exec(); //执行 QSqlRecord recode = query.record(); //recode保存查询到一些内容信息,如表头、列数等等 int column = recode.count(); //获取读取结果的列数 QString s1 = recode.fieldName(0); //获取第0列的列名 while (query.next()) { testInfo tmp; tmp.UsreName = query.value("UsreName").toString(); tmp.IP = query.value("IP").toString(); tmp.Port = query.value("Port").toString(); tmp.PassWord = query.value("PassWord").toString(); tmp.Type = query.value("Type").toString(); infoVect.push_back(tmp); //将查询到的内容存到testInfo向量中 } for (int i=0; i<infoVect.size(); i++) //打印输出 { qDebug() << infoVect[i].UsreName << ":" \ << infoVect[i].IP << ":" \ << infoVect[i].Port << ":" \ << infoVect[i].PassWord << ":" \ << infoVect[i].Type; } //插入数据 query.prepare("INSERT INTO T_USER_MANAGE (UsreName, IP, Port, PassWord, Type) VALUES (:UsreName, :IP, :Port, :PassWord, :Type)"); query.bindValue(":UserName", "user4"); //给每个插入值标识符设定具体值 query.bindValue(":IP", "192.168.1.5"); query.bindValue(":Port", "5004"); query.bindValue(":PassWord", "55555"); query.bindValue(":Type", "operator"); query.exec(); //更改表中 UserName=user4 的Type属性为admin query.prepare("UPDATE T_USER_MANAGE SET Type='admin' WHERE UserName='user4'"); query.exec(); //删除表中 UserName=user4的用户信息 query.prepare("DELETE FROM T_USER_MANAGE WHERE UserName='user4'"); query.exec(); query.clear(); /**************************使用QSqlQuery操作数据库END***********************/ return 0; }

    使用QSqlQueryModel来访问 QSqlQueryModel类带有Model字样,相信你已经猜到我们可以用他来关联试图,就能把数据库的内容显示到视图上,当然,常规的操作也是可以的,但是我们只说说怎么用这个类来把数据库中的内容显示到是视图中,这里我们选择的视图类为QTableView,直接上代码吧

    #include <QtWidgets/QApplication> #include <QCoreApplication> #include <QDebug> #include <QString> #include <QTableView> #include <QtSql/QSqlDatabase> #include <QtSql/QSqlQueryModel> int main(int argc, char *argv[]) { QApplication a(argc, argv); QSqlDatabase db = QSqlDatabase::addDatabase("QSQLITE"); db.setDatabaseName(QApplication::applicationDirPath() + "/CONFIG/" + "CONFIG.db"); if (!db.open()) { return 0; } QSqlQueryModel *model = new QSqlQueryModel; model->setQuery("SELECT * FROM T_USER_MANAGE", db); //从给定的数据库db执行sql操作, db需预先制定并打开 int column = model->columnCount(); //获取列数 int row = model->rowCount(); //获取行数 model->setHeaderData(0, Qt::Horizontal, QStringLiteral("用户名")); //设置表头,如不设置则使用数据库中的默认表头 model->setHeaderData(1, Qt::Horizontal, QStringLiteral("IP地址")); model->setHeaderData(2, Qt::Horizontal, QStringLiteral("端口")); model->setHeaderData(3, Qt::Horizontal, QStringLiteral("密码")); model->setHeaderData(4, Qt::Horizontal, QStringLiteral("用户类型")); QTableView *view = new QTableView; //定义视图,只能用于显示,不能修改数据库 view->setFixedSize(500, 200); view->setModel(model); view->show(); return a.exec(); }

     

    Processed: 0.010, SQL: 8