QT day6

这篇具有很好参考价值的文章主要介绍了QT day6。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

目录

思维导图

学生管理系统


思维导图

QT day6,qt,开发语言

QT day6,qt,开发语言

学生管理系统

ui界面

QT day6,qt,开发语言

头文件

#ifndef WIDGET_H
#define WIDGET_H

#include <QWidget>
#include <QSqlDatabase> //数据库管理类
#include <QSqlQuery> //执行sql语句类
#include <QSqlRecord> //数据库记录类
#include <QSqlError> //数据库错误类
#include <QMessageBox> //消息对话框类


QT_BEGIN_NAMESPACE
namespace Ui { class Widget; }
QT_END_NAMESPACE

class Widget : public QWidget
{
    Q_OBJECT

public:
    Widget(QWidget *parent = nullptr);
    ~Widget();

private slots:
    void on_addbtn_clicked();

    void on_showBtn_clicked();

    void on_updateBtn_clicked();

    void on_deleteBtn_clicked();

private:
    Ui::Widget *ui;
    QSqlDatabase db; //实例化一个数据库

};
#endif // WIDGET_H

源文件

#include "widget.h"
#include "ui_widget.h"

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

    //判断是否有该数据库
    if(!db.contains("stuInfo.db"))
    {
        //说明数据库不存在,需要创建数据库
        db = QSqlDatabase::addDatabase("QSQLITE"); //驱动为sqlite3
        //给刚才创建的数据库设置数据库名
        db.setDatabaseName("stuInfo");
    }

    //打开数据库
    if(!db.open())
    {
        QMessageBox::information(this,"","打开数据库失败!");
        return;
    }

    //创建数据库表

    //实例化一个执行sql语句的对象
    QSqlQuery query;
    //准备sql语句
    QString sql = "create table if not exists stu_info_table("
                  "id integer primary key autoincrement,"
                  "numb integer,"
                  "name varchar(20),"
                  "sex varchar(4),"
                  "score integer)";
    //执行sql语句
    if(query.exec(sql))
    {
        QMessageBox::information(this,"","创建数据库表成功!");
    }
    else
    {
        QMessageBox::information(this,"","创建数据库表失败!");
    }
}

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

//添加按钮对应的槽函数处理
void Widget::on_addbtn_clicked()
{
    //获取ui界面上的学生信息
    int numb = ui->numberEdit->text().toUInt();
    QString name = ui->nameEdit->text();
    QString sex = ui->sexEdit->text();
    int score = ui->scoreEdit->text().toUInt();

    //判断用户是否填写完整信息
    if(numb==0 || name.isEmpty() || sex.isEmpty() || score==0)
    {
        QMessageBox::information(this,"","请将信息填写完整!");
        return;
    }

    //实例化一个执行sql语句的对象
    QSqlQuery query;
    //准备sql语句
    QString sql = QString("insert into stu_info_table(numb,name,sex,score)"
                          "values(%1,'%2','%3',%4)").arg(numb).arg(name).arg(sex).arg(score);

    //执行sql语句
    //执行sql语句
    if(query.exec(sql))
    {
        QMessageBox::information(this,"","添加成功!");
    }
    else
    {
        QMessageBox::information(this,"","添加失败!");
    }


}

//显示按钮对应的槽函数处理
void Widget::on_showBtn_clicked()
{
    ui->tableWidget->clear();

    //实例化一个执行sql语句的对象
    QSqlQuery query;
    //准备sql语句
    QString sql = "select * from Stu_info_table";
    //执行sql语句
    if(!query.exec(sql))
    {
        QMessageBox::information(this,"","查询失败!");
        return;
    }
    //所查询的信息就已经存放到query对象中
    int i=0; //记录行号
    while (query.next())
    {
        for(int j=0;j<query.record().count();j++)
        {
            //将数据放到ui界面上
            ui->tableWidget->setItem(i,j,new QTableWidgetItem(query.value(j+1).toString()));
        }
        i++; //行数递增
    }
}

//修改按钮对应的槽函数处理
void Widget::on_updateBtn_clicked()
{
    //实例化一个执行sql语句的对象
    QSqlQuery query;

    int numb = ui->numberEdit->text().toUInt();
    QString name = ui->nameEdit->text();
    QString sex = ui->sexEdit->text();
    int score = ui->scoreEdit->text().toUInt();

    if(numb!=0)
    {
        if(!name.isEmpty())
        {
            //准备sql语句
            QString sql = QString("update Stu_info_table set name='%1' where numb=%2").arg(name).arg(numb);
            //执行sql语句
            if(query.exec(sql))
            {
                QMessageBox::information(this,"","姓名修改成功!");
            }
            else
            {
                QMessageBox::information(this,"","姓名修改失败!");
                return;
            }
        }
        if(!sex.isEmpty())
        {
            //准备sql语句
            QString sql = QString("update Stu_info_table set sex='%1' where numb=%2").arg(sex).arg(numb);
            //执行sql语句
            if(query.exec(sql))
            {
                QMessageBox::information(this,"","性别修改成功!");
            }
            else
            {
                QMessageBox::information(this,"","性别修改失败!");
                return;
            }
        }
        if(score!=0)
        {
            //准备sql语句
            QString sql = QString("update Stu_info_table set score=%1 where numb=%2").arg(score).arg(numb);
            //执行sql语句
            if(query.exec(sql))
            {
                QMessageBox::information(this,"","分数修改成功!");
            }
            else
            {
                QMessageBox::information(this,"","分数修改失败!");
                return;
            }
        }
        if(name.isEmpty() && sex.isEmpty() && score==0)
        {
            QMessageBox::information(this,"","请输入要修改的内容!");
            return;
        }
    }else
    {
        QMessageBox::information(this,"","请输入要修改的学生学号!");
    }
}


//删除按钮对应的槽函数处理
void Widget::on_deleteBtn_clicked()
{
    //实例化一个执行sql语句的对象
    QSqlQuery query;
    int numb = ui->numberEdit->text().toUInt();

    //准备sql语句
    QString sql = QString("delete from Stu_info_table where numb=%1").arg(numb);

    //执行sql语句
    if(query.exec(sql))
    {
        QMessageBox::information(this,"","删除成功!");
    }
    else
    {
        QMessageBox::information(this,"","删除失败!");
        return;
    }
}

QT day6,qt,开发语言QT day6,qt,开发语言

QT day6,qt,开发语言QT day6,qt,开发语言QT day6,qt,开发语言QT day6,qt,开发语言文章来源地址https://www.toymoban.com/news/detail-791578.html

到了这里,关于QT day6的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • C语言:选择+编程(每日一练Day6)

    目录 ​编辑选择题:  题一: 题二: 题三: 题四: 题五: 编程题: 题一:至少是其他数字两倍的最大数 思路一: 思路二: 题二:两个数组的交集  思路一: 本人实力有限可能对一些地方解释和理解的不够清晰,可以自己尝试读代码,或者评论区指出错误,望海涵! 感

    2024年02月11日
    浏览(42)
  • 2023.07.29 驱动开发DAY6

    通过epoll实现一个并发服务器 服务器 客户端 运行结果  

    2024年02月15日
    浏览(36)
  • QT支持多种开发语言

    QT主要是一个C++应用程序框架,但它也提供了对其他一些编程语言的官方或非官方支持。以下是QT支持的一些语言版本及其特点。北京木奇移动技术有限公司,专业的软件外包开发公司,欢迎交流合作。 1.Python (PyQt)  : PyQt是QT的官方Python绑定,允许Python开发者使用QT库来创建

    2024年04月29日
    浏览(38)
  • 【Visual Studio】Qt 的实时绘图曲线功能,使用 C++ 语言,配合 Qt 开发串口通信界面

    知识不是单独的,一定是成体系的。更多我的个人总结和相关经验可查阅这个专栏:Visual Studio。 战斗背景:做了个串口接收界面,用来接收传输过来的信号。但是光用数字显示太单调,需要用图线显示出来。 战略目标:干掉它。 战术路线:Qt 绘图可以使用 Qt Charts,先了解

    2024年02月11日
    浏览(38)
  • 【VisualStudio】使用 C++ 语言开发 Qt 环境配置教程

    知识不是单独的,一定是成体系的。更多我的个人总结和相关经验可查阅这个专栏:Visual Studio。 先上一张效果图,具体步骤主要分为以下三步。 这一步不再赘述,注意一定要安装 C++ 语言。 可以参考这个教程 Visual Studio 2022安装与使用教程。 这一步也不再赘述,网上搜索教

    2024年02月10日
    浏览(63)
  • 【VisualStudio】基于 Visual Studio 使用 C++ 语言开发 Qt 环境配置教程

    知识不是单独的,一定是成体系的。更多我的个人总结和相关经验可查阅这个专栏:Visual Studio。 先上一张效果图,具体步骤主要分为以下三步。 这一步不再赘述,注意一定要安装 C++ 语言。 可以参考这个教程 Visual Studio 2022安装与使用教程。 这一步也不再赘述,网上搜索教

    2024年02月15日
    浏览(50)
  • 【Visual Studio】使用 C++ 语言,配合 Qt,开发了一个串口通信界面

    知识不是单独的,一定是成体系的。更多我的个人总结和相关经验可查阅这个专栏:Visual Studio。 我要使用的功能比较简单,主要包含扫描串口、打开串口、发送数据、接收数据、暂停按钮、停止按钮,因此接下里将围绕这几个功能依次更新。 我的工程项目名字叫 “GUI”。

    2024年02月11日
    浏览(57)
  • 【Visual Studio】报错 C2653,使用 C++ 语言,配合 Qt 开发串口通信界面

    知识不是单独的,一定是成体系的。更多我的个人总结和相关经验可查阅这个专栏:Visual Studio。 这个 Bug 是我做这个工程时遇到的:【Visual Studio】Qt 的实时绘图曲线功能,使用 C++ 语言,配合 Qt 开发串口通信界面。 使用 C++ 语言,配合 Qt 开发串口通信界面,在添加 Widget 做

    2024年02月11日
    浏览(40)
  • 【Visual Studio】报错 ASSERT: “i >= 0 && i < size()“,使用 C++ 语言,配合 Qt 开发串口通信界面

    知识不是单独的,一定是成体系的。更多我的个人总结和相关经验可查阅这个专栏:Visual Studio。 这个 Bug 是我做这个工程时遇到的:【Visual Studio】Qt 的实时绘图曲线功能,使用 C++ 语言,配合 Qt 开发串口通信界面。 使用 C++ 语言,配合 Qt 开发串口通信界面,在调试动态绘图

    2024年02月11日
    浏览(41)
  • QT---day1(QT的介绍、常用类及组件)

      思维导图:  

    2024年02月15日
    浏览(32)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包