qt连接tcp通信和连接数据库

news2025/1/11 5:55:52

通过数据库实现学生管理系统

widget.cpp

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

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

    //判断数据库对象是否包含了自己使用的数据库  Studemt.db
    if(!db.contains("Student.db"))
    {
        //添加一个数据库
        db = QSqlDatabase::addDatabase("QSQLITE");                   //表示使用的是sqlite3版本的数据库

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

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

    //此时说明数据库创建完毕并打开
    //就可以创建数据表了
    //需要使用SQL语句,需要使用QSQLQuerry类对象完成
    //准备SQL语句
    QString sql = "create table if not exists myTable("              //创建表的sql语句
                    "id integer primary key autoincrement,"          //id主键,允许自增
                    "numb integer,"                                  //学号,是整形
                    "name varchar(10),"                              //姓名   字符串
                    "score integer,"
                    "sex varchar(4))";                                //性别 字符串

    //定义语句执行者
    QSqlQuery querry;

    //使用queery执行SQL语句
    if(!querry.exec(sql))
    {
        QMessageBox::information(this,"失败","创建表失败");
    }else
    {
        QMessageBox::information(this,"成功","创建表成功");
    }
}


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

//录入按钮对应的槽函数
void Widget::on_btn1_clicked()
{
    //获取ui界面中要存入数据库中的数据
    int numb_ui = ui->edit1->text().toInt();            //获取学号
    QString name_ui = ui->edit2->text();                //获取姓名
    int score_ui = ui->edit3->text().toInt();           //获取分数
    QString sex_ui = ui->edit4->text();                 //获取性别

    if(numb_ui == 0 || name_ui.isEmpty() || score_ui == 0||sex_ui.isEmpty())
    {
        QMessageBox::information(this,"提示","请将信息填充完整");
        return ;
    }

    //准备SQL语句
    QString sql = QString("insert into myTable(numb,name,score,sex)"
                  "values(%1,'%2',%3,'%4')")
            .arg(numb_ui).arg(name_ui).arg(score_ui).arg(sex_ui);

    //定义语句执行官
    QSqlQuery querry;

    //调用执行者的相关函数执行SQL语句
    if(!querry.exec(sql))
    {
        QMessageBox::information(this,"失败","插入失败");
    }else
    {
        QMessageBox::information(this,"成功","插入成功");
    }
}

//展示按钮对应的槽函数
void Widget::on_btn2_clicked()
{
    //准备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();

        //要找到每条一条记录 中的每个数据使用
           //qDebug() << querry.record().value(2);

        //返回当前记录对应数据项的个数
           //querry.record().count();

        //将记录的某一项的数据转变成了字符串
           //querry.record().value(2).toString();

        //将数据库中的表格展示到ui界面
           //ui->tableWidget->setItem();

        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_btn3_clicked()
{
    //获取ui界面中要存入数据库中的数据
    int numb_ui = ui->edit1->text().toInt();            //获取学号
    QString name_ui = ui->edit2->text();                //获取姓名
    int score_ui = ui->edit3->text().toInt();           //获取分数
    QString sex_ui = ui->edit4->text();                 //获取性别

    if(numb_ui != 0)
    {
        ui->tableWidget->clear();
        //准备SQL语句
        QString sql = QString("select * from myTable where %1 == numb").arg(numb_ui);

        //准备语句执行者
        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++;                             //进行下一行
        }

    }else if(!name_ui.isEmpty())
    {
        ui->tableWidget->clear();
        //准备SQL语句
        QString sql = QString("select * from myTable where '%2' == name").arg(name_ui);

        //准备语句执行者
        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++;                             //进行下一行
        }

    }else if(score_ui != 0)
    {
        ui->tableWidget->clear();
        //准备SQL语句
        QString sql = QString("select * from myTable where %3 == score").arg(score_ui);

        //准备语句执行者
        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++;                             //进行下一行
        }
    }else if(!sex_ui.isEmpty())
    {
        ui->tableWidget->clear();
        //准备SQL语句
        QString sql = QString("select * from myTable where '%4' == sex").arg(sex_ui);

        //准备语句执行者
        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_btn4_clicked()
{
    //获取ui界面中要存入数据库中的数据
    int numb_ui = ui->edit1->text().toInt();            //获取学号
    QString name_ui = ui->edit2->text();                //获取姓名
    int score_ui = ui->edit3->text().toInt();           //获取分数
    QString sex_ui = ui->edit4->text();                 //获取性别

    if(numb_ui != 0 )
    {
        ui->tableWidget->clear();
        //准备SQL语句
        QString sql = QString("delete from myTable where %1 == numb").arg(numb_ui);

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

        //准备SQL语句
        QString sql1 = "select * from myTable";
        querry.exec(sql1);
        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++;                             //进行下一行
        }
    }else if(!name_ui.isEmpty())
    {
        ui->tableWidget->clear();
        //准备SQL语句
        QString sql = QString("delete from myTable where '%2' == name").arg(name_ui);

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

        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++;                             //进行下一行
        }

    }else if(score_ui != 0)
    {
        ui->tableWidget->clear();
        //准备SQL语句
        QString sql = QString("delete from myTable where %3 == score").arg(score_ui);

        //准备语句执行者
        QSqlQuery querry;
        if(!querry.exec(sql))
        {
            QMessageBox::information(this,"失败","删除失败");
            return;
        }
        else
        {
             QMessageBox::information(this,"成功","删除成功");
        }
        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++;                             //进行下一行
        }
    }else if(!sex_ui.isEmpty())
    {
        ui->tableWidget->clear();
        //准备SQL语句
        QString sql = QString("delete from myTable where '%4' == sex").arg(sex_ui);

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

        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++;                             //进行下一行
        }
    }

}

widget.h

#ifndef WIDGET_H
#define WIDGET_H

#include <QWidget>
#include<QSqlDatabase>                         //数据库管理类
#include<QSqlQuery>                            //执行SQL语句对应的类
#include<QSqlRecord>                           //记录类
#include<QMessageBox>
#include<QDebug>



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_btn1_clicked();

    void on_btn2_clicked();

    void on_btn3_clicked();

    void on_btn4_clicked();

private:
    Ui::Widget *ui;

    //定义一个数据库对象
    QSqlDatabase db;
};
#endif // WIDGET_H

 

 tcp服务器

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

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

    //给服务器指针实例化对象
    server = new QTcpServer(this);
}

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

//启动服务器按钮对应的槽函数
void Widget::on_btn_clicked()
{

    //获取ui界面上的端口号
    quint16 port = ui->edit->text().toUInt();


    if(!server->listen(QHostAddress::Any,port))
    {
        QMessageBox::critical(this,"失败","服务器启动失败");
        return;
    }else
    {
        QMessageBox::information(this,"成功","服务器启动成功");
    }
    connect(server,&QTcpServer::newConnection,this,&Widget::newConnection_slot);
}

//处理的newConnection信号的槽函数的实现
void Widget::newConnection_slot()
{
    qDebug() << "有新的客户端发来连接请求";
    QTcpSocket *s = server->nextPendingConnection();
    //将获取的套接字存放到客户端容器中
    clientList.push_back(s);
    connect(s,&QTcpSocket::readyRead,this,&Widget::redyRead_slot);
}

//关于readyRead信号的槽函数
void Widget::redyRead_slot()
{
    //删除客户端链表中的无效客户端套接字
    for(int i=0;i<clientList.count();i++)
    {
        if(clientList[i]->state() == 0)
        {
            clientList.removeAt(i);               // 将下标为i的客户端移除掉
        }
    }

    //遍历所有客户端,查看是哪个客户端发来数据
    for(int i=0;i<clientList.count();i++)
    {

        if(clientList[i]->bytesAvailable() != 0)
        {
            QByteArray msg = clientList[i]->readAll();
            //将数据展示到ui界面上
            ui->msglist->addItem(QString::fromLocal8Bit(msg));
            //接接受的消息发送到所有客户端,发送给所有客户端
            for(int j=0;j<clientList.count();j++)
            {
                clientList[j]->write(msg);
            }
        }
    }
}

tcp客户端

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

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

    //客户端指针实例化空间
    socket = new QTcpSocket(this);

    connect(socket,&QTcpSocket::connected,this,&Widget::connected_slot);

    connect(socket,&QTcpSocket::readyRead,this,&Widget::readyRead_slot);

    connect(socket,&QTcpSocket::disconnected,this,&Widget::disconnected_slot);
}

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

//连接服务器按钮对应的槽函数
void Widget::on_btn2_clicked()
{
    //获取ui界面的信息
    userName = ui->edit2->text();                       //获取用户名
    QString hostName = ui->edit3->text();               //获取主机地址
    quint16 port= ui->edit4->text().toUInt();           //获取端口号

    socket->connectToHost(hostName,port);

}


void Widget::connected_slot()
{
    QMessageBox::information(this,"成功","连接服务器成功");

    //顺便向服务器发送一条信息
    QString msg = userName + ":进入聊天室";

    socket->write(msg.toLocal8Bit());
}

//关于readyRead信号的槽函数
void Widget::readyRead_slot()
{
    //读取该客户端中的数据
    QByteArray msg = socket->readAll();

    //将数据展示在ui界面
    ui->listWidget->addItem(QString::fromLocal8Bit(msg));
}

//发送消息
void Widget::on_btn1_clicked()
{
    //获取ui界面中编辑文本的内容
    QString m = ui->edit1->text();

    //整合要发送的信息
    QString msg = userName + ":" + m;

    //将消息发送给服务器
    socket->write(msg.toLocal8Bit());

    //将消息编辑框中的内容清空
    ui->edit1->clear();
}

//断开服务器
void Widget::on_btn3_clicked()
{
    //准备要发送的信息
    QString msg = userName + ":离开聊天室";
    socket->write(msg.toLocal8Bit());


    socket->disconnectFromHost();

}


void Widget::disconnected_slot()
{
    QMessageBox::information(this,"退出","退出成功");
}

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

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

相关文章

国产集成开发环境工具 CEC-IDE

本周&#xff0c;国内首款适配国产操作系统、自主可控的集成开发环境工具 CEC-IDE 终于开放下载了。公开报道显示&#xff0c;这款集成开发环境工具由数字广东公司联合麒麟软件打造&#xff0c;于今年 6 月份首次亮相。本周&#xff0c;软件上线仅几天内就在知乎和 GitHub 上引…

《存储IO路径》专题:块设备层多队列blk-mq架构

我们想象一下&#xff0c;你是一个餐厅的厨师&#xff0c;你要准备很多不同的菜肴&#xff0c;而每种菜肴需要不同的食材和烹饪时间。如果每道菜都按照需要的顺序来准备&#xff0c;那么你的工作效率一定会非常低。为了提高效率&#xff0c;你会怎么做呢&#xff1f; 在linux架…

分布式 - 服务器Nginx:基础系列之Nginx静态资源优化配置指令sendfile | tcp_nopush | tcp_nodelay

文章目录 1. sendfile 指令2. tcp_nopush 指令3. tcp_nodelay 指令 1. sendfile 指令 请求静态资源的过程&#xff1a;客户端通过网络接口向服务端发送请求&#xff0c;操作系统将这些客户端的请求传递给服务器端应用程序&#xff0c;服务器端应用程序会处理这些请求&#xff…

qt day5 数据库,tcp

数据库 widget.h #ifndef WIDGET_H #define WIDGET_H#include <QWidget> #include <QSqlDatabase>//数据库管理类 #include <QSqlRecord>//记录类 #include <QSqlQuery>//执行sql语句对应的类 #include <QMessageBox> #include<QDebug> …

Linux命令200例:man用于显示和阅读关于Linux内置命令的使用说明

&#x1f3c6;作者简介&#xff0c;黑夜开发者&#xff0c;CSDN领军人物&#xff0c;全栈领域优质创作者✌。CSDN专家博主&#xff0c;阿里云社区专家博主&#xff0c;2023年6月csdn上海赛道top4。 &#x1f3c6;数年电商行业从业经验&#xff0c;历任核心研发工程师&#xff0…

玻璃工艺品可以走墨西哥专线吗?

玻璃工艺品作为一种精美独特的艺术品&#xff0c;经常被人们用来装饰家居或作为礼品赠送。然而&#xff0c;对于想要将这些玻璃工艺品运往墨西哥的商家或个人来说&#xff0c;如何选择最便捷的运输方式成为一个重要的问题。那么&#xff0c;玻璃工艺品可以走墨西哥专线吗? 墨西…

VSCode配置Python以及扩展

无论您是经验丰富的开发人员还是刚刚开始编码冒险&#xff0c;正确设置 VS Code 都可能是将您的技能提升到新水平的秘诀。因此&#xff0c;让我们深入探索在 Visual Studio Code 的虚拟墙内打造崇高编码天堂的艺术&#xff01; 为什么选择 VS 代码&#xff1f; VS Code 已成为 …

探索iVX:颠覆传统低代码平台的新潮流

&#x1f935;‍♂️ 个人主页&#xff1a;艾派森的个人主页 ✍&#x1f3fb;作者简介&#xff1a;Python学习者 &#x1f40b; 希望大家多多支持&#xff0c;我们一起进步&#xff01;&#x1f604; 如果文章对你有帮助的话&#xff0c; 欢迎评论 &#x1f4ac;点赞&#x1f4…

判断对象是否发生变化,常用于监听页面表单是否修改并给出保存提示

本文主要封装方法&#xff0c;实现用户离开表单编辑页面时弹出提示框&#xff0c;若表单数据发生变化&#xff0c;则提示用户是否保存当前页面的信息&#xff0c;如图&#xff1a; 封装方法&#xff1a; /*** 比较俩个对象之间的差异&#xff0c;项目中多处用到监听表单数据是…

一文入门Web网站安全测试

文章目录 Web网页安全风险评估1. 数据泄漏2. 恶意软件传播3. 身份伪装和欺诈 测试Web网页的安全性常见方法和工具漏洞扫描器手动漏洞测试漏洞利用工具Web应用程序防火墙&#xff08;WAF&#xff09;测试渗透测试代码审查社会工程学测试 推荐阅读 Web网页安全风险评估 越来越多…

L1-058 6翻了(Python实现) 测试点全过

前言&#xff1a; {\color{Blue}前言&#xff1a;} 前言&#xff1a; 本系列题使用的是&#xff0c;“PTA中的团体程序设计天梯赛——练习集”的题库&#xff0c;难度有L1、L2、L3三个等级&#xff0c;分别对应团体程序设计天梯赛的三个难度。更新取决于题目的难度&#xff0c;…

ROS通信机制之动作(Action)服务的实践

1、动作概述 讲完了 服务 之后&#xff0c;接下来就是通信的第三种机制&#xff0c;动作。在上节我们知道服务的应用场景是需要在有限时间内完成&#xff0c;而对于一些比较复杂的任务&#xff0c;需要耗时比较长&#xff0c;甚至是不确定时间的时候&#xff0c;就需要用到动作…

20.添加HTTP模块

添加一个简单的静态HTTP。 这里默认读者是熟悉http协议的。 来看看http请求Request的例子 客户端发送一个HTTP请求到服务器的请求消息&#xff0c;其包括&#xff1a;请求行、请求头部、空行、请求数据。 HTTP之响应消息Response 服务器接收并处理客户端发过来的请求后会返…

尚硅谷SpringMVC (9-13)

九、HttpMessageConverter HttpMessageConverter &#xff0c;报文信息转换器&#xff0c;将请求报文转换为 Java 对象&#xff0c;或将 Java 对象转换为响应报文 HttpMessageConverter提供了两个注解和两个类型&#xff1a; RequestBody &#xff0c; ResponseBody &#xff…

如何创建美观的邮件模板并通过qq邮箱的SMTP服务向用户发送

最近在写注册功能的自动发送邮箱告知验证码的功能&#xff0c;无奈根本没有学过前端&#xff0c;只有写Qt的qss基础&#xff0c;只好借助网页设计自己想要的邮箱格式&#xff0c;最终效果如下: 也推销一下自己的项目ShaderLab&#xff0c;可运行ShaderToy上的大部分着色器代码&…

Weblogic漏洞(二)之 Weblogic漏洞环境安装

Weblogic漏洞环境安装 这里我们使用Kali虚拟机安装docker并搭建vulhub靶场来进行Weblogic漏洞环境的安装 安装 docker #更新软件 apt-get update #安装CA证书 apt-get install -y apt-transport-https ca-certificates #安装docker apt install docker.io #查看docker是否安…

【商业案例应用】C端产品设计流程——团购产品案例

文章目录 1、项目背景介绍2、产品前期分析3、产品规划4、总结 1、项目背景介绍 2、产品前期分析 3、产品规划 4、总结

SSH连接安卓手机Termux —— Android手机

文章目录 前言1.安装ssh2.安装cpolar内网穿透3.远程ssh连接配置4.公网远程连接5.固定远程连接地址 前言 使用安卓机跑东西的时候&#xff0c;屏幕太小&#xff0c;有时候操作不习惯。不过我们可以开启ssh&#xff0c;使用电脑PC端SSH远程连接手机termux。 本次教程主要实现在…

C语言入门 Day_13 二维数组

目录 前言&#xff1a; 1.字符串 2.创建二维数组 3.使用二维数组 4.易错点 5.思维导图 前言&#xff1a; 我们学习了字符类型char&#xff0c;我们可以用char来表示一个大写或者小写的字母&#xff0c;但真实应用中我们往往使用的是多个字符组成的一个单词或者句子。 …

Linux gdb单步调试的原理

文章目录 一、demo演示二、原理分析参考资料 一、demo演示 .section .data message:.string "Hello, World!\n" len . - message.section .text .globl _start _start:# 调用 write() 函数输出 "Hello, World!"mov $1, %rax # 系统调用号为 1…