QT+SQLite
在QT中使用sqlite數據庫,有多種使用方法,在這里我只提供幾種簡單,代碼簡短的方法,包括一些特殊字符處理。在這里也給大家說明一下,如果你每次要存儲的數據量很大,建議使用事務(代碼中有體現),萬條數據不到一秒吧。
用SQlite建立一個簡單學生管理數據庫
數據庫中有兩個表一個是class和student。
class表結構
student表結果
創建工程
我的工程如下:
直接上代碼(看注釋更通透)
student.pro文件添加sql模塊。
QT += core gui
QT += sql #添加數據庫模塊
greaterThan(QT_MAJOR_VERSION, 4): QT += widgetsCONFIG += c++17# You can make your code fail to compile if it uses deprecated APIs.
# In order to do so, uncomment the following line.
#DEFINES += QT_DISABLE_DEPRECATED_BEFORE=0x060000 # disables all the APIs deprecated before Qt 6.0.0SOURCES += \main.cpp \Student.cppHEADERS += \Student.hFORMS += \Student.ui# Default rules for deployment.
qnx: target.path = /tmp/$${TARGET}/bin
else: unix:!android: target.path = /opt/$${TARGET}/bin
!isEmpty(target.path): INSTALLS += target
student.h文件添加相關定義。
#ifndef STUDENT_H
#define STUDENT_H#include <QWidget>#include <QSqlDatabase>
#include <QSqlQuery>
#include <QSqlError>
#include <QSqlRecord>
#include <QDebug>QT_BEGIN_NAMESPACE
namespace Ui { class Student; }
QT_END_NAMESPACEclass Student : public QWidget
{Q_OBJECTpublic:Student(QWidget *parent = nullptr);~Student();//定義一個變量,用于增刪改查QString queryString;void Add();//添加數據,不支持大量數據快速添加void Delete();//刪除數據,支持大量數據快速刪除void Update();//更新數據,若更新大量數據,可以先快速刪除后在快速添加void Select();//查詢數據,支持大量數據快速查詢void FastAdd();//在sqlite中快速添加大量數據private:Ui::Student *ui;QSqlDatabase DB;//定義數據庫名稱
};
#endif // STUDENT_H
student.cpp文件編輯。(值得一提的是,在數據庫刪除操作中,有時候要判斷限制條件是否為空,在代碼中已體現)
#include "Student.h"
#include "ui_Student.h"Student::Student(QWidget *parent): QWidget(parent), ui(new Ui::Student)
{ui->setupUi(this);//打開數據庫DB = QSqlDatabase::addDatabase("QSQLITE");DB.setDatabaseName("./StudentDB.db");//打開數據庫if (DB.open()){qDebug() << "Database opened successfully!";}else{qDebug() << "無法打開數據庫:" << DB.lastError().text();}Add();//添加數據Select();//查詢數據Update();//更新數據Delete();//刪除數據FastAdd();//對大量數據進行快速添加,嘗試過添加幾千條數據,不到一秒就添加完成
}Student::~Student()
{delete ui;
}void Student::Add()//增
{/** 在班級表中添加數據,添加的數據為班級名稱:一班班主任:李主任班級人數:25*/queryString = QString("insert into class(class_name, class_teacher ,student_number) values('%1','%2',%3) ").arg("一班").arg("李主任").arg(25);QSqlQuery query;//執行sql語句if(query.exec(queryString)){qDebug()<<"insert data Successful!";}else {qDebug()<<"insert data Failed!";}
}void Student::Delete()//刪
{//在這里有時候要判斷限制條件是否為空,這時候可以用這個sql語句,當班級名稱不為空時刪除//queryString = QString("delete from class where class_name is not null");queryString = QString("delete from class where class_name = '%1'").arg("一班");QSqlQuery query(queryString);if(query.exec()){qDebug()<<"Delete data Successful!";}else {qDebug()<<"Delete data Failed!";}
}void Student::Update()//改
{//更新數據,將班級名稱作為限制條件進行數據更新queryString = QString("update class set class_teacher='%1' ,student_number=%2 where class_name='%3' ").arg("張主任").arg(30).arg("一班");QSqlQuery query;if (query.exec(queryString)){qDebug()<<"updata data Successful!";}else{qDebug()<<"updata data Failed!";}
}void Student::Select()//查
{queryString = QString("select * from class where class_name = '%1'").arg("一班");QSqlQuery query(queryString);while(query.next()){QString class_teacher = query.value("class_teacher").toString();int student_number = query.value("student_number").toInt();qDebug()<<"班主任:"<<class_teacher;qDebug()<<"班級人數:"<<student_number;}
}void Student::FastAdd()//對大量數據進行快速添加,嘗試過添加幾千條數據,不到一秒就添加完成
{//使用事務DB.transaction();//開啟事務QSqlQuery query;query.prepare("INSERT INTO class (class_name, class_teacher, student_number) VALUES (?, ?, ?)");for (int i = 0; i < 100; ++i) {query.bindValue(0, "二班");query.bindValue(1, "張三");query.bindValue(2, i);query.exec();}DB.commit();//一次性提交,省去大量時間
}
運行完之后都出現successful,就說明,你已經掌握了qt+sqlite的增刪改查。