QT使用SQLite数据库超详细教程(增删改查、对大量数据快速存储和更新)

 更新时间:2024年01月12日 08:54:20   作者:椿融雪  
这篇文章主要给大家介绍了关于QT使用SQLite数据库的相关资料,其中包括增删改查以及对大量数据快速存储和更新,SQLite是一种嵌入式关系型数据库管理系统,它是一个软件库,提供了一个自包含、无服务器、零配置的、事务性的SQL数据库引擎,需要的朋友可以参考下

QT+SQLite

在QT中使用sqlite数据库,有多种使用方法,在这里我只提供几种简单,代码简短的方法,包括一些特殊字符处理。在这里也给大家说明一下,如果你每次要存储的数据量很大,建议使用事务(代码中有体现),万条数据不到一秒吧。

用SQlite建立一个简单学生管理数据库

数据库中有两个表一个是classstudent

Alt

class表结构

Alt

student表结果

Alt

创建工程

我的工程如下:

Alt

直接上代码(看注释更通透)

student.pro文件添加sql模块。

QT       += core gui
QT       += sql #添加数据库模块
greaterThan(QT_MAJOR_VERSION, 4): QT += widgets

CONFIG += 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.0

SOURCES += \
    main.cpp \
    Student.cpp

HEADERS += \
    Student.h

FORMS += \
    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_NAMESPACE

class Student : public QWidget
{
    Q_OBJECT

public:
    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的增删改查。

总结

到此这篇关于QT使用SQLite数据库(增删改查、对大量数据快速存储和更新)的文章就介绍到这了,更多相关QT使用SQLite增删改查内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • C/C++ Windows SAPI实现文字转语音功能

    C/C++ Windows SAPI实现文字转语音功能

    本文通过封装Windows SAPI(Speech Application Programming Interface),提供了一个现代化的C++接口实现文字转语音功能,这篇文章重点给大家介绍C/C++ Windows SAPI自实现文字转语音功能,感兴趣的朋友一起看看吧
    2025-02-02
  • Qt可视化大屏布局的实现

    Qt可视化大屏布局的实现

    数据可视化大屏在项目中的使用很常见,本文主要介绍了Qt可视化大屏布局的实现,具有一定的参考价值,感兴趣的可以了解一下
    2024-02-02
  • C++数据结构之哈希算法详解

    C++数据结构之哈希算法详解

    这篇文章主要为大家详细介绍了C++数据结构中哈希算法的相关资料,文中的示例代码讲解详细,具有一定的借鉴价值,希望对大家有所帮助
    2022-12-12
  • C++实现特殊矩阵的压缩存储算法

    C++实现特殊矩阵的压缩存储算法

    在实际存储时,会发现矩阵中有许多值相同的数据或有许多零数据,且分布呈现出一定的规律,称这类型的矩阵为特殊矩阵。本文将利用C++实现特殊矩阵的压缩存储,感兴趣的可以了解一下
    2022-08-08
  • C++中各种初始化方式示例详解

    C++中各种初始化方式示例详解

    这篇文章主要给大家介绍了关于C++中各种初始化方式的相关资料,文中通过示例代码介绍的非常详细,对大家学习或者使用C++具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧。
    2017-10-10
  • 数据结构之伸展树详解

    数据结构之伸展树详解

    这篇文章主要介绍了数据结构之伸展树详解,本文对伸展树(Splay Tree)的单旋转操作、一字型旋转、之字形旋转区间操作等理论知识做了讲解,并给出实现代码,需要的朋友可以参考下
    2014-08-08
  • C++实现LeetCode(17.电话号码的字母组合)

    C++实现LeetCode(17.电话号码的字母组合)

    这篇文章主要介绍了C++实现LeetCode(17.电话号码的字母组合),本篇文章通过简要的案例,讲解了该项技术的了解与使用,以下就是详细内容,需要的朋友可以参考下
    2021-07-07
  • C++深入浅出讲解缺省参数

    C++深入浅出讲解缺省参数

    所谓缺省参数,顾名思义,就是在声明函数的某个参数的时候为之指定一个默认值,在调用该函数的时候如果采用该默认值,你就无须指定该参数。缺省参数使用主要规则:调用时你只能从最后一个参数开始进行省略,换句话说,如果你要省略一个参数,你必须省略它后面所有的参数
    2022-07-07
  • C语言实现简易扫雷游戏

    C语言实现简易扫雷游戏

    这篇文章主要为大家详细介绍了C语言实现简易扫雷游戏,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2020-03-03
  • 使用C++程序获取新浪行情数据的方法

    使用C++程序获取新浪行情数据的方法

    这篇文章介绍了在一定的周期范围内去抓取新浪中行情数据,通过更新数据来缓解构造模拟数据与真实数据差异性,感兴趣的朋友可以了解一下
    2015-07-07

最新评论