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, "信息", "删除成功");
}

展示

查找

删除

相关推荐
Laurence1 小时前
C++ 引入第三方库(一):直接引入源文件
开发语言·c++·第三方库·添加·添加库·添加包·源文件
蒸汽求职2 小时前
机器人软件工程(Robotics SDE):特斯拉Optimus落地引发的嵌入式C++与感知算法人才抢夺战
大数据·c++·算法·职场和发展·机器人·求职招聘·ai-native
charlee442 小时前
最小二乘问题详解17:SFM仿真数据生成
c++·计算机视觉·sfm·数字摄影测量·无人机航测
Tanecious.3 小时前
蓝桥杯备赛:Day4-P9749 公路
c++·蓝桥杯
旖-旎3 小时前
分治(库存管理|||)(4)
c++·算法·leetcode·排序算法·快速选择算法
Tanecious.4 小时前
蓝桥杯备赛:Day3-P1102 A-B 数对
c++·蓝桥杯
Tanecious.4 小时前
蓝桥杯备赛:Day3-P1918 保龄球
c++·蓝桥杯
良木生香4 小时前
【C++初阶】:C++类和对象(下):构造函数promax & 类型转换 & static & 友元 & 内部类 & 匿名对象 & 超级优化
c语言·开发语言·c++
三雷科技5 小时前
使用 `dlopen` 动态加载 `.so` 文件
开发语言·c++·算法
旖-旎6 小时前
分治(快速选择算法)(3)
c++·算法·leetcode·排序算法·快速选择