qt day5 数据库,tcp

 数据库

widget.h

#ifndef WIDGET_H
#define WIDGET_H

#include <QWidget>
#include <QSqlDatabase>//数据库管理类
#include <QSqlRecord>//记录类
#include <QSqlQuery>//执行sql语句对应的类
#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_inputbtn_clicked();

    void on_showbtn_clicked();

    void on_searchbtn_clicked();

    void on_deletebtn_clicked();

private:
    Ui::Widget *ui;
    //定义一个数据库对象
    QSqlDatabase db;
};
#endif // WIDGET_H

 widget.cpp

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

Widget::Widget(QWidget *parent)
    : QWidget(parent)
    , ui(new Ui::Widget)
{
    ui->setupUi(this);
    //判断 数据库对象是否包含了自己使用的数据库student.db
    if(!db.contains("student.db"))
    {
        //添加一个数据库
        //函数原型:static QsqlDatabase addDatabase(const Qstring& type);
        //参数:数据库的版本

        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;
    //使用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->numEdit->text().toUInt();   //获取ui界面的学号
    QString name_ui=ui->nameEdit->text();   //获取ui界面上的新名
    int score_ui = ui->scoreEdit->text().toInt();   //获取ui界面上的成绩
    QString sex_ui= ui->sexEdit->text();        //获取ui界面上的性别

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


    //Qstring s1 = Qstring("%61,%2,9%3").arg(526).arg(3.14).arg("I love China");
    //定义语句执行官
    QSqlQuery querry;
    //调用执行者的相关函数执行sql语句
    if(!querry.exec(sql))
    {
        QMessageBox ::information(this,"失败","插入数据失败");
    }else
    {
        QMessageBox ::information(this,"成功","数据录入成功");
    }


}
//展示按钮对应的槽函数
void Widget::on_showbtn_clicked()
{
    //准备sql语句
    QString sql = "select * from myTable";
    //准备语句执行者
    QSqlQuery querry;//执行sql语句
    if(!querry.exec(sql))
    {
        QMessageBox ::information(this ,"失败","查询失败");
        return;
    }
    //此时,将查找到的所有结果,全部都放在querry对象中了
    //可以通过next函数不断遍历查询结
    int i=0;  //记录行号
    while(querry.next())
    {
        //遍历的就是任意一组记录:querry.record
        // querry.record();
        // qDebug()<<querry .record()
        //要找到每条记录中的每个数据使用querry.record().value(i)
        //qDebug()<<querry.record().value(2);
        // querry.record().value();//返回当前记录对应数据项的个数
        // 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_searchbtn_clicked()
{
    //获取ui界面中要存入数据库中的数据
    int numb_ui = ui->numEdit->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 )
    {
        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_deletebtn_clicked()
{
    int numb_ui = ui->numEdit->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) {
        QString sql = QString("delete from myTable where %1 = numb").arg(numb_ui);

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

    } else if (!name_ui.isEmpty()) {
        QString sql = QString("delete from myTable where '%1' = name").arg(name_ui);

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

    } else if (score_ui != 0) {
        QString sql = QString("delete from myTable where %1 = score").arg(score_ui);

        QSqlQuery query;
        if (!query.exec(sql)) {
            QMessageBox::information(this, "失败", "删除失败");
            return;
        } else {
            QMessageBox::information(this, "成功", "删除成功");
        }
    } else if (!sex_ui.isEmpty()) {
        QString sql = QString("delete from myTable where '%1' = sex").arg(sex_ui);

        QSqlQuery query;
        if (!query.exec(sql)) {
            QMessageBox::information(this, "失败", "删除失败");
            return;
        } else {
            QMessageBox::information(this, "成功", "删除成功");
        }
    }
    //清空
    ui->tableWidget->clear();
    //准备sql语句
    QString sql = "select * from myTable";
    //准备语句执行者
    QSqlQuery querry;
    querry.exec(sql);
    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++;                             //进行下一行
    }
}

服务器:

#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_btn1_clicked()
{
    //获取ui上的端口号
    quint16 port=ui->portEdit->text().toUInt();


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

    connect(server,&QTcpServer::newConnection,this,&Widget::newconnection_slot);

}

//处理newconneion信号的槽函数
void Widget::newconnection_slot()
{
    qDebug()<<"新的客户端发来连接请求了" ;

    QTcpSocket *s=server->nextPendingConnection();
    //将获取的套接字存放到客户端中
    clientList.push_back(s);

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


}

//处理readRead信号的槽函数
void Widget::readyRead_slot()
{

    for(int i=0;i<clientList.count();i++)
    {

        if(clientList[i]->state()==0)
        {
            clientList.removeAt(i);
        }
    }


    for(int i=0;i<clientList.count();i++)
    {


        if(clientList[i]->bytesAvailable()!=0)
        {

            QByteArray msg=clientList[i]->readAll();
            ui->msglist->addItem(QString::fromLocal8Bit(msg));

            for(int j=0;j<clientList.count();j++)
            {
                clientList[j]->write(msg);
            }

        }
    }

}

 客户端

#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_connectbtn_clicked()
{
    //获取ui界面的信息
    userName =ui->usernameEdit->text();//获取用户名
    QString hostName= ui->ipEdit->text();//获取主机地址
    quint16 port = ui->portEdit->text().toUInt();//获取端口号


    socket->connectToHost(hostName,port);
}


//关于connected信号的槽函数的定义
void Widget::connected_slot()
{
QMessageBox::information (this,"成功","连接服务器成功");

QString msg = userName + ":进入聊天室";

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

}

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

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

//发送按钮对应的槽函数
void Widget::on_sendbtn_clicked()
{
    //获取ui界面中的编辑的文本内容
    QString m=ui->msgEdit->text();

    //整合要发送的信息
    QString msg=userName+":"+m;
    //将消息发送给服务器
    socket->write(msg.toLocal8Bit());
    //将消息编辑框中的内容清空
    ui->msgEdit->clear( ) ;

}
//断开服务器按钮对应的槽函数
void Widget::on_disconnectbtn_clicked()
{
    //准备要发送的信息

    QString msg=userName+":离开聊天室";
    socket->write(msg.toLocal8Bit());

    socket->disconnectFromHost();

}

//disconnected信号对应的槽函数实现
void Widget::disconnected_slot()
{
        QMessageBox::information(this,"退出","断开成功");
}

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值