本文介绍: QT+SQLite (对数据进行增删改查

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&gt;

//添加相应的头文件
#include <QSqlDatabase&gt;
#include <QSqlQuery&gt;
#include <QSqlError&gt;
#include <QSqlRecord&gt;
#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();//查询数据


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();//删除数据
}

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;
    }
}




运行完之后都出现successful,就说明,你已经掌握qt+sqlite的增删改查
在这里插入图片描述

原文地址:https://blog.csdn.net/HXX904/article/details/134785454

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任

如若转载,请注明出处:http://www.7code.cn/show_39626.html

如若内容造成侵权/违法违规/事实不符,请联系代码007邮箱suwngjj01@126.com进行投诉反馈,一经查实,立即删除

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注