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

展示

查找

删除

相关推荐
tumu_C1 小时前
C++模板特化实战:在使用开源库boost::geometry::index::rtree时,用特化来让其支持自己的数据类型
c++·开源
杜若南星1 小时前
保研考研机试攻略(满分篇):第二章——满分之路上(1)
数据结构·c++·经验分享·笔记·考研·算法·贪心算法
Neophyte06081 小时前
C++算法练习-day40——617.合并二叉树
开发语言·c++·算法
云空1 小时前
《InsCode AI IDE:编程新时代的引领者》
java·javascript·c++·ide·人工智能·python·php
写bug的小屁孩1 小时前
websocket初始化
服务器·开发语言·网络·c++·websocket·网络协议·qt creator
湖南罗泽南2 小时前
Windows C++ TCP/IP 两台电脑上互相传输字符串数据
c++·windows·tcp/ip
可均可可3 小时前
C++之OpenCV入门到提高005:005 图像操作
c++·图像处理·opencv·图像操作
zyx没烦恼3 小时前
【STL】set,multiset,map,multimap的介绍以及使用
开发语言·c++
机器视觉知识推荐、就业指导3 小时前
基于Qt/C++与OpenCV库 实现基于海康相机的图像采集和显示系统(工程源码可联系博主索要)
c++·qt·opencv
myloveasuka4 小时前
类与对象(1)
开发语言·c++