9.4 数据库 TCP

news2024/11/28 2:29:13
#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, "信息", "删除成功");
}

展示 

查找 

 

删除 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/976141.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

对可再生能源和微电网集成研究的新控制技术和保护算法进行基线和测试及静态、时域和频率分析研究(Matlab代码实现)

&#x1f4a5;&#x1f4a5;&#x1f49e;&#x1f49e;欢迎来到本博客❤️❤️&#x1f4a5;&#x1f4a5; &#x1f3c6;博主优势&#xff1a;&#x1f31e;&#x1f31e;&#x1f31e;博客内容尽量做到思维缜密&#xff0c;逻辑清晰&#xff0c;为了方便读者。 ⛳️座右铭&a…

vue2 封装通用表格数据筛选的重置摁钮

放弃冗余代码吧&#xff0c;封装个混入 封装逻辑 // 重置表格筛选参数 export const queryReset {methods: {queryReset(form, method "getData", fn) {if (!this[form]) {form "queryForm";}this.$data[form] this.$options.data()[form];this[form…

2023开学礼《乡村振兴战略下传统村落文化旅游设计》许少辉八一新书对外经济贸易大学图书馆

2023开学礼《乡村振兴战略下传统村落文化旅游设计》许少辉八一新书对外经济贸易大学图书馆

2023最新UI工作室官网个人主页源码/背景音乐/随机壁纸/一言

2023最新UI工作室官网个人主页源码/支持背景音乐/随机壁纸/一言 功能介绍&#xff1a; 载入动画 站点简介 Hitokoto 一言 日期及时间 实时天气 时光进度条 音乐播放器 移动端适配 打开文件&#xff1b;index.html和setting.json修改替换你的相关信息&a…

Windows下安装配置Nginx

nginx安装 官网下载地址 https://nginx.org/en/download.html 推荐使用稳定版本 截止时间2023年9月5日稳定版本为 1.24.0 百度网盘 链接&#xff1a;https://pan.baidu.com/s/1cXm-jN2fMzKdVMRhbG72Fg 提取码&#xff1a;9hcq 下载完成以后,得到nginx压缩包; 双击启动nginx.…

2023年模拟IC就业形式怎么样? 还能不能入了?(附最新薪资行情)

虽然说模拟IC的门槛高&#xff0c;难度大&#xff0c;但相比数字IC的话竞争要小一点。而且薪资也比数字IC要高一些。 想要学好模拟芯片设计&#xff0c;首先要懂电路&#xff0c;懂器件&#xff0c;你要理解你的器件是怎么工作的&#xff0c;它在芯片上是什么样子&#xff0c;…

如何使用代理配置快速定位接口测试脚本问题?

在调试接口用例过程中&#xff0c;如果响应结果和预期结果不一致&#xff0c;则需要检查请求信息。通过代理获取自动化测试中的请求响应信息&#xff0c;对比与正常请求响应的区别&#xff0c;就能够更直观的排查请求错误&#xff0c;相当于编写代码时的 debug 功能。 实战练习…

华为数通安全产品介绍

HiSecEngine USG12000系列防火墙&#xff08;以下简称USG12000系列&#xff09;是华为公司推出的首款T级AI防火墙&#xff0c;在网络边界实时防护已知与未知威胁&#xff0c;通常部署在云计算数据中心&#xff0c;大型企业及园区网出口&#xff0c;为数据中心、企业及园区网络提…

[MySQL]查看数据库大小

查看库大小 例如&#xff1a;查看当前MySQL中数据总量超过2GB的库&#xff1a; select table_schema as 数据库,table_rows as 记录数,data_size as 数据容量(GB),index_size as 索引容量(MB) from (selecttable_schema,sum(table_rows) as table_rows,sum(truncate(data_leng…

1794086 -F110 清算日期与付款时的付款日期不同

确实没有想到设置的地方在这里。 症状 用户在事务 F110 中执行付款&#xff0c;且清算日期字段 (BSEG-AUGDT) 未设置为付款日期。 重现问题 执行事务 F110 并执行自动付款。完成后&#xff0c;检查凭证中的“清算日期”字段。该日期与付款日期不同。 例如&#xff0c;您具…

jQuery 层次选择器

jQuery 层次选择器 &#xff08;0&#xff09;测试前的准备工作 A. 定义测试对象 B. 定义测试对象的 CSS 样式 C. 再定义一些测试用的 button。 &#xff08;1&#xff09;所有后代选择器(A B) 所有后代&#xff0c;包括其直接后代及间接后代。 &#xff08;2&#xff09;直…

统计学极简入门-统计学简介

1.统计学简介 听说你已经被统计学劝退&#xff0c;被Python唬住……先别着急划走&#xff0c;看完这篇再说&#xff01; 先说结论&#xff0c;大多数情况下的学不会都不是知识本身难&#xff0c;而是被知识的传播者劝退的。 比如大佬们授课&#xff0c;虽逻辑严谨、思维缜密…

并行计算之OpenMP简介

OpenMP环境安装 基于ubuntu20.04 sudo apt-get update sudo apt-get install libomp-devOpenMP概述 面向多线程并行编码的编译指导语句&#xff0c;如 #pragma omp parallel#pragma omp for#pragma omp sections包含相应的函数接口库和runtime(运行时系统) omp_get_thread_n…

21.SPI万能驱动

spi万能驱动&#xff1a;spidev.c文件 存放在内核/drivers/spi/spidev.c文件。 内核开放的通用版本的spi驱动。 内核集成spidev驱动模块&#xff0c;开机后会中的加载此模块。 支持修改多种spi通信参数。 两个数据类型 spidev_data结构体 fops中的函数结构都要用到&#xff…

C/C++ CMake编译工具轻度使用

目录 CMake编译工具 一、CMake概述 二、CMake的使用 2.1 注释 2.1.1 注释行 2.1.2 注释块 2.2 源文件 2.1.1 共处一室 2.1.2 VIP包房 2.3 私人定制 2.2.1 定义变量 2.2.2 指定使用的C标准 2.2.3 指定输出的路径 2.4 搜索文件 2.3.1 方式1 2.3.2 方式2 2.5 包含…

WebGL射击游戏的优化

myshmup.com 允许在浏览器中创建 shmup(射击)游戏,我们可以使用具有创意通用许可证的资源或上传自己的艺术作品和声音。 创建的游戏可以在网站上发布。 该平台不需要编码,游戏对象的配置是在用户界面的帮助下执行的,后端是使用Django框架开发的,编辑器 UI 用 Javascript …

Spring项目配置

1.创建项目 2.修改编码格式为UTF-8 3.检查或配置代码⾃动补全功能 4.检查或配置⾃动导包 5.检查或配置Maven&#xff0c;可以⽤国内仓库镜像 6.idea识别Maven项⽬&#xff1a;在Notifications视图中会提⽰Load Maven Project&#xff0c;点击即可。 7.开启热部署 a.确认 pom.x…

vue制作页面水印

1.新建一个js js的代码 let watermark {}let setWatermark (str) > {let id 1.23452384164.123412415if (document.getElementById(id) ! null) {document.body.removeChild(document.getElementById(id))}let can document.createElement(canvas)can.width 500can.he…

一文彻底吃透自动化测试框架所有知识

定义测试自动化 在任何行业中&#xff0c;自动化通常被解释为自动处理流程&#xff0c;而这些流程几乎不需要人工干预。在软件行业&#xff0c;测试自动化意味着使用许可版本或开源的自动化工具对软件应用程序执行各种测试。用技术术语来说&#xff0c;测试自动化框架是一组定制…

css自学框架之图片灯箱展示

实现的功能是页面中的图片单击&#xff0c;在灯箱中显示&#xff0c;单击按钮上下切换&#xff0c;单击灯箱退出展示&#xff0c;效果如下GIF展示。 实现步骤还是老样子&#xff0c;三方面工作一是CSS、二是JavaSxcript&#xff0c;三是HTML&#xff0c;下面开始一步一步实现&…