9.4 数据库 TCP

cpp 复制代码
#include "widget.h"
#include "ui_widget.h"

Widget::Widget(QWidget *parent)
    : QWidget(parent)
    , ui(new Ui::Widget)
{
    ui->setupUi(this);

    //判断数据库对象是否包含了自己使用的数据库
    if(!db.contains("Stu.db")){
        //不存在数据库,添加一个数据库
        //static QSqlDatabase addDatabase(const QString& type);
        //参数:数据库的版本
        //返回值:添加的数据库
        db = QSqlDatabase::addDatabase("QSQLITE");  //表明使用的是sqlite3版本的数据库

        //给数据库命名
        db.setDatabaseName("Stu.db");
    }

    //打开数据库
    if(!db.open()){  //如果没有设置
        QMessageBox::information(this, "信息", "数据库打开失败");
        return ;
    }

    //此时说明数据库已经创建出来,并打开了,就可以创建数据表了
    //创建数据表需要sql语句,需要使用QSQLQuerry类对象完成
    //准备sql语句
    QString sql = "create table if not exists mytable("
                    "id integer primary key autoincrement,"     //id主键,允许自增
                    "numb integer,"                             //学号,整形
                    "name varchar(10),"                         //姓名,字符串
                    "sex varchar(4),"                          //性别,字符串
                    "score integer)";                           //分数
    //定义语句执行者
    QSqlQuery querry;
    //使用querry执行sql语句
    if(!querry.exec(sql)){
        QMessageBox::information(this, "信息", "创建表格失败");
    }
    else{
        QMessageBox::information(this, "信息", "创建表格成功");
    }
}

Widget::~Widget()
{
    delete ui;
}

//录入按钮对应的槽函数
void Widget::on_inputbtn_clicked()
{
    //获取ui界面要存入数据库的数据
    int numb_ui = ui->numbedit->text().toInt();
    QString name_ui = ui->nameedit->text();
    int score_ui = ui->scoreedit->text().toInt();
    QString sex_ui = ui->sexedit->text();

    if(numb_ui==0 || name_ui.isNull() || score_ui==0 || sex_ui.isNull()){
        QMessageBox::information(this, "信息", "请将信息填写完整");
        return ;
    }
    //准备sql语句
    QString sql = QString("insert into mytable(numb, name, sex, score)"
                  "values(%1, '%2', '%3', %4)").arg(numb_ui).arg(name_ui).arg(sex_ui).arg(score_ui);
    //定义语句执行官
    qDebug() << sql;
    QSqlQuery querry;
    if(!querry.exec(sql)){
        QMessageBox::information(this, "信息", "插入数据失败");
        return ;
    }
    QMessageBox::information(this, "信息", "数据录入成功");
}

//展示按钮对应的槽函数
void Widget::on_showbtn_clicked()
{
    ui->tableWidget->clear();
    //准备sql语句
    QString sql = "select * from mytable";
    //准备语句执行者
    QSqlQuery querry;
    if(!querry.exec(sql)){
        QMessageBox::information(this, "信息", "查询失败");
        return ;
    }

    //此时,将查询到的结果,全部放到querry对象中
    //可以通过next函数不断遍历查询结果
    int i = 0;
    while(querry.next()){
        //遍历的就是任意一组记录:querry.record
        //querry.record().value(1);

        //将数据库中的表格展示到ui界面
                     //当前记录对应数据项的个数
        for(int j=0;j<querry.record().count()-1;j++){
            ui->tableWidget->setItem(i,j,new QTableWidgetItem(querry.record().value(j+1).toString()));
        }
        i++;//进入下一行
    }
}

//查找
void Widget::on_searchbtn_clicked()
{
    ui->tableWidget->clear();
    //获取ui界面要存入数据库的数据
    int numb_ui = ui->numbedit->text().toInt();
    QString name_ui = ui->nameedit->text();
    int score_ui = ui->scoreedit->text().toInt();
    QString sex_ui = ui->sexedit->text();
    //准备sql语句
    QString sql = QString("select * from mytable where "
                          "numb=%1 and name='%2' and score=%3 and sex='%4'").arg(numb_ui).arg(name_ui).arg(score_ui).arg(sex_ui);
    qDebug() << sql;
    QSqlQuery querry;
    if(!querry.exec(sql)){
        QMessageBox::information(this, "信息", "条件查询失败");
        return ;
    }
    int i=0;
    while(querry.next()){
        for(int j=0;j<querry.record().count()-1;j++){
            ui->tableWidget->setItem(i,j,new QTableWidgetItem(querry.record().value(j+1).toString()));
        }
        i++;
    }
}

//删除
void Widget::on_deletebtn_clicked()
{
    //获取ui界面要存入数据库的数据
    int numb_ui = ui->numbedit->text().toInt();
    QString name_ui = ui->nameedit->text();
    int score_ui = ui->scoreedit->text().toInt();
    QString sex_ui = ui->sexedit->text();
    //准备sql语句
    QString sql = QString("delete from mytable where "
                          "numb=%1 and name='%2' and score=%3 and sex='%4'").arg(numb_ui).arg(name_ui).arg(score_ui).arg(sex_ui);
    QSqlQuery querry;
    if(!querry.exec(sql)){
        QMessageBox::information(this, "信息", "删除失败");
        return ;
    }
    QMessageBox::information(this, "信息", "删除成功");
}

展示

查找

删除

相关推荐
️停云️36 分钟前
【滑动窗口与双指针】不定长滑动窗口
c++·算法·leetcode·剪枝·哈希
charlie11451419139 分钟前
嵌入式现代C++教程: 构造函数优化:初始化列表 vs 成员赋值
开发语言·c++·笔记·学习·嵌入式·现代c++
IT=>小脑虎1 小时前
C++零基础衔接进阶知识点【详解版】
开发语言·c++·学习
码农小韩2 小时前
基于Linux的C++学习——指针
linux·开发语言·c++·学习·算法
小L~~~2 小时前
绿盟校招C++研发工程师一面复盘
c++·面试
微露清风2 小时前
系统性学习C++-第十九讲-unordered_map 和 unordered_set 的使用
开发语言·c++·学习
_Lzk666888_2 小时前
洛谷用户2002780求关注
c++·其他
无限进步_3 小时前
【C语言&数据结构】对称二叉树:镜像世界的递归探索
c语言·开发语言·数据结构·c++·git·算法·visual studio
X***07883 小时前
C语言在嵌入式系统开发中的应用与挑战
c++
小芒果_013 小时前
整理归并排序
c++·算法·排序算法·信息学奥赛