QT5中使用SQLite的實現方法
SQLite(sql)是一款開源輕量級的數據庫軟件,不需要server,可以集成在其他軟件中,非常適合嵌入式系統。
Qt5以上版本可以直接使用SQLite。
1、修改.pro文件,添加SQL模塊:
QT += sql
2、main.cpp代碼如下:
#include "mainwindow.h" #include <QApplication> //添加頭文件 #include <qdebug.h> #include <QSqlDatabase> #include <QSqlError> #include <QSqlQuery> int main(int argc, char *argv[]) { QApplication a(argc, argv); //建立並打開數據庫 QSqlDatabase database; database = QSqlDatabase::addDatabase("QSQLITE"); database.setDatabaseName("MyDataBase.db"); if (!database.open()) { qDebug() << "Error: Failed to connect database." << database.lastError(); } else { qDebug() << "Succeed to connect database." ; } //創建表格 QSqlQuery sql_query; if(!sql_query.exec("create table student(id int primary key, name text, age int)")) { qDebug() << "Error: Fail to create table."<< sql_query.lastError(); } else { qDebug() << "Table created!"; } //插入數據 if(!sql_query.exec("INSERT INTO student VALUES(1, \"Wang\", 23)")) { qDebug() << sql_query.lastError(); } else { qDebug() << "inserted Wang!"; } if(!sql_query.exec("INSERT INTO student VALUES(2, \"Li\", 23)")) { qDebug() << sql_query.lastError(); } else { qDebug() << "inserted Li!"; } //修改數據 sql_query.exec("update student set name = \"QT\" where id = 1"); if(!sql_query.exec()) { qDebug() << sql_query.lastError(); } else { qDebug() << "updated!"; } //查詢數據 sql_query.exec("select * from student"); if(!sql_query.exec()) { qDebug()<<sql_query.lastError(); } else { while(sql_query.next()) { int id = sql_query.value(0).toInt(); QString name = sql_query.value(1).toString(); int age = sql_query.value(2).toInt(); qDebug()<<QString("id:%1 name:%2 age:%3").arg(id).arg(name).arg(age); } } //刪除數據 sql_query.exec("delete from student where id = 1"); if(!sql_query.exec()) { qDebug()<<sql_query.lastError(); } else { qDebug()<<"deleted!"; } //刪除表格 sql_query.exec("drop table student"); if(sql_query.exec()) { qDebug() << sql_query.lastError(); } else { qDebug() << "table cleared"; } //關閉數據庫 database.close(); return a.exec(); }
3、應用程序輸出如下:
4、創建的 MyDataBase.db 在build的這個文件夾下:
D:\QT\project\build-sl-Desktop_Qt_5_10_1_MinGW_32bit-Debug
到此這篇關於QT5中使用SQLite的實現方法的文章就介紹到這瞭,更多相關QT5使用SQLite內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!
推薦閱讀:
- Qt操作SQLite數據庫的教程詳解
- Qt入門學習之數據庫操作指南
- QT連接MYSQL數據庫的詳細步驟
- C/C++ Qt 數據庫QSql增刪改查組件應用教程
- C/C++ Qt 數據庫與Chart歷史數據展示