QT--day5

注册

mainwindow.h

#ifndef MAINWINDOW_H
#define MAINWINDOW_H#include <QMainWindow>
#include<QPushButton>
#include<QLineEdit>
#include<QLabel>
#include <QMessageBox>
#include<QString>
#include<QSqlDatabase>          //数据库管理类
#include<QSqlQuery>              //执行sql语句的类
#include<QSqlRecord>              //数据库记录的类
#include "form.h"
#include <QDebug>
QT_BEGIN_NAMESPACE
namespace Ui { class MainWindow; }
QT_END_NAMESPACEclass MainWindow : public QMainWindow
{Q_OBJECTpublic:MainWindow(QWidget *parent = nullptr);~MainWindow();private:Ui::MainWindow *ui;QLineEdit *zh;QLineEdit *mm;Form *f1;QSqlDatabase db;
signals:void my_sig();void jump();
public slots:void btn1_slot();void btn2_slot();void btn3_slot();
};
#endif // MAINWINDOW_H

mainwindow.cpp

#include "mainwindow.h"
#include "ui_mainwindow.h"MainWindow::MainWindow(QWidget *parent): QMainWindow(parent), ui(new Ui::MainWindow)
{ui->setupUi(this);//设置固定大小this->setFixedSize(400,300);//设置窗口标题this->setWindowTitle("HUAQI");//设置窗口图标this->setWindowIcon(QIcon("D:\\Qt\\icon\\icon\\wodepeizhenshi.png"));//构建两个按钮QPushButton *btn1=new QPushButton(QIcon("D:\\Qt\\icon\\icon\\login.png"),"登录",this);btn1->resize(100,40);btn1->move(150,250);QPushButton *btn2=new QPushButton(QIcon("D:\\Qt\\icon\\icon\\cancel.png"),"取消",this);btn2->resize(btn1->size());btn2->move(btn1->x()+125,btn1->y());connect(btn2,SIGNAL(clicked()),this,SLOT(btn2_slot()));QPushButton *btn3=new QPushButton("注册",this);btn3->resize(btn1->size());btn3->move(btn1->x()-125,btn1->y());connect(btn3,SIGNAL(clicked()),this,SLOT(btn3_slot()));//构建两个行编辑器QLineEdit *edit1=new QLineEdit(this);edit1->resize(200,30);edit1->setEchoMode(QLineEdit::Password);edit1->setText("123456");edit1->move(125,btn1->y()-50);QLineEdit *edit2=new QLineEdit(this);edit2->resize(200,30);edit2->setText("admin");edit2->move(125,edit1->y()-50);//构建三个标签QLabel *lab1=new QLabel(this);lab1->resize(30,30);lab1->setPixmap(QPixmap("D:\\Qt\\icon\\icon\\passwd.jpg"));lab1->setScaledContents(true);lab1->move(edit1->x()-40,edit1->y());QLabel *lab2=new QLabel(this);lab2->resize(lab1->size());lab2->setPixmap(QPixmap("D:\\Qt\\icon\\icon\\userName.jpg"));lab2->setScaledContents(true);lab2->move(edit2->x()-40,edit2->y());QLabel *lab3=new QLabel(this);lab3->resize(400,120);lab3->setPixmap(QPixmap("D:\\Qt\\icon\\icon\\logo.png"));lab3->setScaledContents(true);connect(btn1,&QPushButton::clicked,this,&MainWindow::btn1_slot);zh=edit2;mm=edit1;//设置数据库if(!db.contains("mydb.db")){db=QSqlDatabase::addDatabase("QSQLITE");db.setDatabaseName("mydb.db");}//打开数据库if(!db.open()){QMessageBox::information(this,"失败","数据库打开失败");return;}//创建表QString sql="create table if not exists stu_info(""zhanghao varchar(20) primary key,""mima varchar(20))";QSqlQuery querry;if(!querry.exec(sql)){QMessageBox::information(this,"失败","创建表失败");return;}
}MainWindow::~MainWindow()
{delete ui;
}void MainWindow::btn1_slot()
{QString i=zh->text();QString j=mm->text();qDebug()<<i;qDebug()<<j;QString sql=QString("select * from stu_info");QSqlQuery querry;if(!querry.exec(sql)){QMessageBox::information(this,"失败","查询失败");return;}while(querry.next()){qDebug()<<querry.record().value(0).toString();qDebug()<<querry.record().value(1).toString();if(querry.record().value(0).toString()==i&&querry.record().value(1).toString()==j){QMessageBox box(QMessageBox::NoIcon,"成功","登陆成功",QMessageBox::Ok,this);int ret=box.exec();if(ret==QMessageBox::Ok){emit jump();}return;}}QMessageBox box(QMessageBox::Warning,"错误","账号或密码出错",QMessageBox::Yes|QMessageBox::No,this);box.setButtonText(QMessageBox::Yes,"继续");box.setButtonText(QMessageBox::No,"取消");int ret=box.exec();if(ret==QMessageBox::Yes){}else{this->close();}return;}void MainWindow::btn2_slot()
{QMessageBox box(QMessageBox::Question,"退出","确定要退出吗?",QMessageBox::Yes|QMessageBox::No,this);int ret=box.exec();if(ret==QMessageBox::Yes){this->close();}}void MainWindow::btn3_slot()
{QString zhanghao=zh->text();QString mima=mm->text();if(zhanghao.isEmpty()||mima.isEmpty()){QMessageBox::information(this,"提示","信息不完整");return;}QString sql=QString("insert into stu_info(zhanghao,mima)""values('%1','%2')").arg(zhanghao).arg(mima);QSqlQuery querry;if(!querry.exec(sql)){QMessageBox::information(this,"失败","添加失败");return;}else{QMessageBox::information(this,"成功","添加成功");}
}

效果图

添加

登录

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

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

设计模式_解释器模式

解释器模式 案例 角色 1 解释器基类 &#xff08;BaseInterpreter&#xff09; 2 具体解释器1 2 3... (Interperter 1 2 3 ) 3 内容 (Context) 4 用户 (user) 流程 (上下文) ---- 传…

C++入门知识

Hello&#xff0c;今天我们分享一些关于C入门的知识&#xff0c;看完至少让你为后面的类和对象有一定的基础&#xff0c;所以在讲类和对象的时候&#xff0c;我们需要来了解一些关于C入门的知识。 什么是C C语言是结构化和模块化的语言&#xff0c;适合处理较小规模的程序。对…

代码随想录算法训练营 动态规划part06

一、完全背包 卡哥的总结&#xff0c;还挺全代码随想录 (programmercarl.com) 二、零钱兑换 II 518. 零钱兑换 II - 力扣&#xff08;LeetCode&#xff09; 被选物品之间不需要满足特定关系&#xff0c;只需要选择物品&#xff0c;以达到「全局最优」或者「特定状态」即可。 …

eclipse如何引入lombok插件

1. 下载插件 Downloadhttps://projectlombok.org/downloadlombok插件是一个jar包&#xff0c;如下图&#xff1a; 2. 安装插件 双击运行下载的jar包&#xff0c;点击如下按钮&#xff1a; 在弹窗内选择eclipse的启动程序eclipse.exe&#xff0c;注意&#xff01;&#xff01;…

基于springboot+vue的车辆管理系统

博主主页&#xff1a;猫头鹰源码 博主简介&#xff1a;Java领域优质创作者、CSDN博客专家、公司架构师、全网粉丝5万、专注Java技术领域和毕业设计项目实战 主要内容&#xff1a;毕业设计(Javaweb项目|小程序等)、简历模板、学习资料、面试题库、技术咨询 文末联系获取 项目介绍…

4、SpringBoot_Mybatis、Druid、Juint整合

五、SSM整合 1.整合Mybatis 1.1springmvc 整合回顾 导入坐标 <dependency><groupId>org.springframework</groupId><artifactId>spring-jdbc</artifactId><version>5.2.17.RELEASE</version></dependency><dependency>…

XAPI项目架构:应对第三方签名认证的设计与调整

《XAPI项目》&#xff1a;GitHub仓库&#xff08;勿打&#x1f6ab;小破站一个&#xff09; 该项目是基于鱼皮的《API开发平台》项目的需求和架构设计上进行Golang版本开发的。 这篇文章&#xff0c;主要内容是记录在《XAPI项目》的原架构上&#xff0c;为了应对第三方签名认证…

js中的数据结构:栈,队列,链表,字典哈希表,树

栈&#xff1a;先进后出 队列&#xff1a;先进先出 链表&#xff1a; 单链表&#xff1a; 双链表&#xff1a; 环形链表&#xff1a;最后一个数据的next指针不是指向null&#xff0c;指向的是任意之间的一个数据&#xff0c;形成一个环 数组和链表的区别&#xff1a; 字典和哈…

Docker Desktop 界面功能介绍,添加国内镜像源

目录 镜像源修改设置 其他偏好设置 镜像源修改设置 默认情况下&#xff0c;Docker Desktop会从Docker Hub下载镜像&#xff0c;但在国内由于网络的原因&#xff0c;下载速度可能较慢&#xff0c;配置国内镜像源可以提速镜像下载。在Docker Desktop中配置镜像源非常简单&…

LLM各层参数详细分析(以LLaMA为例)

网上大多分析LLM参数的文章都比较粗粒度&#xff0c;对于LLM的精确部署不太友好&#xff0c;在这里记录一下分析LLM参数的过程。 首先看QKV。先上transformer原文 也就是说&#xff0c;当h&#xff08;heads&#xff09; 1时&#xff0c;在默认情况下&#xff0c; W i Q W_i^…

2023/09/20 day4 qt

做一个动态指针钟表 头文件 #ifndef WIDGET_H #define WIDGET_H#include <QWidget> #include <QPainter> //绘制事件类 #include <QPaintEvent> //画家类 #include <QTime> #include <QTimer> #include <QTimerEvent> QT_BEGIN…

用于设计 CNN 的 7 种不同卷积

一 说明 最近对CNN架构的研究包括许多不同的卷积变体&#xff0c;这让我在阅读这些论文时感到困惑。我认为通过一些更流行的卷积变体的精确定义&#xff0c;效果和用例&#xff08;在计算机视觉和深度学习中&#xff09;是值得的。这些变体旨在保存参数计数、增强推理并利用目标…

rtsp转webrtc的其他几个项目

1&#xff09; mpromonet/webrtc-streamer &#xff08;c开发&#xff09; 把rtsp转webrtc&#xff0c; 通过 load urls from JSON config file ./webrtc-streamer -C config.json 通过exe文件和docker项目实际测试可以显示&#xff0c;但不太稳定加载慢,有时候出错后很难…

7.15 SpringBoot项目实战 【学生入驻】(上):从API接口定义 到 Mybatis查询 串讲

文章目录 前言一、service层 和 dal层方式一、Example方式方式二、Mybatis XML方式方式三、Mybatis 注解方式 二、web层 StudentController最后 前言 接下来我们实战【学生入驻】&#xff0c;对于C端学生端&#xff0c;一切交互开始于知道 当前学生是否入驻、是否有借阅资格&a…

LeetCode 753. 破解保险箱【欧拉回路,DFS】困难

本文属于「征服LeetCode」系列文章之一&#xff0c;这一系列正式开始于2021/08/12。由于LeetCode上部分题目有锁&#xff0c;本系列将至少持续到刷完所有无锁题之日为止&#xff1b;由于LeetCode还在不断地创建新题&#xff0c;本系列的终止日期可能是永远。在这一系列刷题文章…

java字符串压缩和字符串解压

java字符串压缩和字符串解压 运行效果 java工具类 CompressUtil.java import com.alibaba.fastjson.JSON; import com.alibaba.fastjson.serializer.SerializerFeature; import org.apache.commons.codec.binary.Base64;import java.io.BufferedReader; import java.io.Byte…

el-form自定义规则后表单验证validate不生效的问题

1.首先放出结论&#xff0c;自定义验证规则必须降所有的可能全部都return callback出去&#xff0c;不然不会走validate 错误示范 // template <el-formref"ruleFormRef":model"ruleForm":rules"rules"label-width"120px"class&qu…

力扣:105. 从前序与中序遍历序列构造二叉树(Python3)

题目&#xff1a; 给定两个整数数组 preorder 和 inorder &#xff0c;其中 preorder 是二叉树的先序遍历&#xff0c; inorder 是同一棵树的中序遍历&#xff0c;请构造二叉树并返回其根节点。 来源&#xff1a;力扣&#xff08;LeetCode&#xff09; 链接&#xff1a;力扣&am…

Visio——绘制倾斜线段

一、形状 -> 图表和数学图形 -> 多行 二、放置多行线&#xff0c;可以发现存在两个折点 三、选择多行线&#xff0c;右键选择删除点&#xff0c;即可得到倾斜线段

C进阶-数据的存储

数据类型介绍 内置类型&#xff1a; //数据类型中的内置类型 // char //字符数据类型 // short //短整型 // int //整型 // long //长整型 // long long //更长的整型 // float //单精度浮点数 // double //双精度浮点数 //数据类型中的内置类型 单位是字节 // char //字…