9月21日作业

登录代码:

widget.h

#ifndef REGISTER_H
#define REGISTER_H#include <QWidget>
#include <QDebug>
#include <QSqlDatabase>
#include <QSqlQuery>
#include <QMessageBox>namespace Ui {
class Register;
}class Register : public QWidget
{Q_OBJECTpublic:explicit Register(QWidget *parent = nullptr);~Register();public slots:void jump_slot();  //接收跳转信号的槽函数private slots:void on_registerbtn_clicked();private:Ui::Register *ui;};#endif // REGISTER_H

widget.cpp:

#include "widget.h"
#include "ui_widget.h"Widget::Widget(QWidget *parent): QWidget(parent), ui(new Ui::Widget)
{ui->setupUi(this);r = new Register;//连接登录注册按钮的信号与跳转函数QObject::connect(this, &Widget::jump_sign, r, &Register::jump_slot);
}Widget::~Widget()
{delete ui;
}void Widget::jumptoLogin_slot()
{this->show();
}//登录按钮的槽函数实现
void Widget::on_loginbtn_clicked()
{ // 初始化数据库连接QSqlDatabase db = QSqlDatabase::addDatabase("QSQLITE");db.setDatabaseName("G:\\study\\Qt\\C++&Qt\\9.21\\work-Login\\mydatabase.db"); // 设置数据库文件的名称// 打开数据库if (!db.open()){QMessageBox::information(this, "失败", "数据库打开失败");}//从Edit中提取用户名和密码QString username = ui->usernameEdit->text();QString password = ui->passwordEdit->text();//准备sql语句QString sql = QString("select username, password from users where username='%1' and password=%2").arg(username).arg(password);qDebug()<<sql;//准备语句执行者QSqlQuery querry;//执行sql语句if(querry.exec(sql)){while(querry.next()){QString tempname = querry.value(0).toString();QString temppassword = querry.value(1).toString();if(username==tempname && password==temppassword){QMessageBox::information(this,"成功","登陆成功");return;}}QMessageBox::information(this,"失败","账号密码错误");}else{QMessageBox::information(this,"失败","查找错误,请检测账号密码格式");return;}
}
//注册按钮的槽函数实现
void Widget::on_registerbtn_clicked()
{this->hide();   //隐藏登陆界面emit jump_sign();   //发送跳转信号
}

register.h:

#ifndef REGISTER_H
#define REGISTER_H#include <QWidget>
#include <QDebug>
#include <QSqlDatabase>
#include <QSqlQuery>
#include <QMessageBox>namespace Ui {
class Register;
}class Register : public QWidget
{Q_OBJECTpublic:explicit Register(QWidget *parent = nullptr);~Register();public slots:void jump_slot();  //接收跳转信号的槽函数private slots:void on_registerbtn_clicked();private:Ui::Register *ui;};#endif // REGISTER_H

register.cpp:

#include "register.h"
#include "ui_register.h"Register::Register(QWidget *parent) :QWidget(parent),ui(new Ui::Register)
{ui->setupUi(this);}Register::~Register()
{delete ui;
}void Register::jump_slot()
{this->show();
}void Register::on_registerbtn_clicked()
{// 初始化数据库连接QSqlDatabase db = QSqlDatabase::addDatabase("QSQLITE");db.setDatabaseName("G:\\study\\Qt\\C++&Qt\\9.21\\work-Login\\mydatabase.db"); // 设置数据库文件的名称// 打开数据库if (db.open()){qDebug() << "已打开数据库";// 创建表QSqlQuery query;if (query.exec("CREATE TABLE if not exists users (id INTEGER PRIMARY KEY, username TEXT UNIQUE, password INTEGER)")) {qDebug() << "用户表已创建";//从Edit中提取用户名和密码QString username = ui->usernameEdit->text();QString password = ui->passwordEdit->text();//要确保每个编辑器中都有数据if(username.isEmpty() || password==0){QMessageBox::information(this,"提示","请将信息填写完整");return;}// 插入数据QString  sql = QString("INSERT INTO users (username, password) VALUES ('%1', %2)").arg(username).arg(password);qDebug()<<sql;if (query.exec(sql)) {qDebug() << "数据插入成功 ";} else {QMessageBox::information(this, "失败", "数据有误");qDebug() << "数据插入失败";}} else {qDebug() << "用户表创建失败";}// 关闭数据库连接db.close();}else{QMessageBox::information(this, "失败", "打开失败");qDebug() << "数据库打开失败";}
}

思维导图:

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

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

相关文章

Linux开发工具之编辑器-vim

vim简单来说就是一款文本编辑器&#xff0c;用于写代码&#xff0c;更是一款多模式编辑器 vim的基本概念 vim有许多种模式&#xff0c;但是铁三角是以下三种模式&#xff1a;命令模式&#xff0c;插入模式&#xff0c;底行模式 1 正常/普通/命令模式&#xff08;默认打开&…

Docker容器启动失败:找不到映像

Docker容器启动失败&#xff1a;找不到映像 Docker容器启动失败&#xff1a;找不到映像摘要 &#x1f615;引言 &#x1f62e;正文 &#x1f913;为什么会找不到映像&#xff1f; &#x1f615;1. 映像不存在2. 映像标签错误3. 映像不兼容 如何预防和解决问题&#xff1f; &…

权限提升WIN篇(腾讯云,CS,MSF)

溢出漏洞 信息收集 操作系统版本ver&#xff0c;systeminfo漏洞补丁信息systeminfo操作系统位数systeminfo杀软防护tasklist /svc网络netstat -ano,ipconfig当前权限whoami 筛选EXP 根据前面的信息收集中的系统版本&#xff0c;位数和补丁情况筛选出合适的EXP 提权 根据EX…

喜报 | 亮相2023数博会,摘得首届数智金融创新大赛优秀奖

河北正定&#xff0c;千年古城&#xff0c;这里不仅有一幕幕刀光剑影&#xff0c;鼓角争鸣的故事&#xff0c;还有驰名中外的人“一寺四塔”&#xff0c;有宜人的气候&#xff0c;也有汇聚高科技的天下英雄会。 图源于网络 2023年9月6日&#xff0c;河北正定&#xff0c;中国国…

JavaWeb开发-07-MySQL(二)

一.数据库操作-DQL -- 准备测试数据 INSERT INTO tb_emp (id, username, password, name, gender, image, job, entrydate, create_time, update_time) VALUES (1, jinyong, 123456, 金庸, 1, 1.jpg, 4, 2000-01-01, 2022-10-27 16:35:33, 2022-10-27 16:35:35), (2, zhangwuji…

搭建GraphQL服务

js版 GraphQL在 NodeJS 服务端中使用最多 安装graphql-yoga: npm install graphql-yoga 新建index.js: const {GraphQLServer} require("graphql-yoga")const server new GraphQLServer({ typeDefs: type Query { hello(name:String):String! …

Linux CentOS7 tree命令

tree就是树&#xff0c;是文件或文件名输出到控制台的一种显示形式。 tree命令作用&#xff1a;以树状图列出目录的内容&#xff0c;包括文件、子目录及子目录中的文件和目录等。 我们使用ll命令显示只能显示一个层级的普通文件和目录的名称。而使用tree则可以树的形式将指定…

打架识别相关开源数据集资源汇总(附下载链接)

更多数据集分类资源汇总&#xff1a;https://www.cvmart.net/dataSets 监控摄像头下的打架检测 数据集下载链接&#xff1a;http://suo.nz/39IbxQ 该数据集是从包含打架实例的 Youtube 视频中收集的。此外&#xff0c;还包括一些来自常规监控摄像机视频的非打架序列。 总共有…

Linux -- 使用多张gpu卡进行深度学习任务(以tensorflow为例)

在linux系统上进行多gpu卡的深度学习任务 确保已安装最新的 TensorFlow GPU 版本。 import tensorflow as tf print("Num GPUs Available: ", len(tf.config.list_physical_devices(GPU)))1、确保你已经正确安装了tensorflow和相关的GPU驱动&#xff0c;这里可以通…

Mac电脑安装Zulu Open JDK 8 使用 spring-kafka 消费不到Kafka Partition中的消息

一、现象描述 使用Mac电脑本地启动spring-kakfa消费不到Kafka的消息&#xff0c;监控消费组的消息偏移量发现存在Lag的消息&#xff0c;但是本地客户端就是拉取不到&#xff0c;通过部署到公司k8s容器上消息却能正常消费&#xff01; 本地启动的服务消费组监控 公司k8s容器服…

9.2.3.1 【MySQL】XDES Entry链表

当段中数据较少的时候&#xff0c;首先会查看表空间中是否有状态为 FREE_FRAG 的区&#xff0c;也就是找还有空闲空间的碎片区&#xff0c;如果找到了&#xff0c;那么从该区中取一些零碎的页把数据插进去&#xff1b;否则到表空间下申请一个状态为 FREE 的区&#xff0c;也就是…

关于时空数据的培训 GAN:实用指南(第 02/3 部分)

一、说明 在本系列关于训练 GAN 实用指南的第 1 部分中&#xff0c;我们讨论了 a&#xff09; 鉴别器 &#xff08;D&#xff09; 和生成器 &#xff08;G&#xff09; 训练之间的不平衡如何导致模式崩溃和由于梯度消失而导致静音学习&#xff0c;以及 b&#xff09; GAN 对超参…

CTF —— 网络安全大赛(这不比王者好玩吗?)

前言 随着大数据、人工智能的发展&#xff0c;人们步入了新的时代&#xff0c;逐渐走上科技的巅峰。 \ ⚔科技是一把双刃剑&#xff0c;网络安全不容忽视&#xff0c;人们的隐私在大数据面前暴露无遗&#xff0c;账户被盗、资金损失、网络诈骗、隐私泄露&#xff0c;种种迹象…

Conditional DETR(ICCV 21)

Conditional DETR&#xff08;ICCV 21&#xff09; Conditional DETR for Fast Training Convergence 加速detr收敛&#xff08;50 epoch收敛&#xff09; DETR收敛慢的原因 DETR训练收敛速度慢&#xff0c;需要500 epochs DETR的Cross Attention高度依赖content embedding…

软件项目开发的流程及关键点

软件项目开发的流程及关键点 graph LR A[需求分析] --> B[系统设计] B --> C[编码开发] C --> D[测试验证] D --> E[部署上线] E --> F[运维支持]在项目开发的流程中&#xff0c;首先是进行需求分析&#xff0c;明确项目的目标和功能要求。接下来是系统设计&am…

数据结构与算法——13.队列的拓展

这篇文章主要讲一下双端队列&#xff0c;优先队列&#xff0c;阻塞队列等队列的拓展内容。 目录 1.队列拓展概述 2.双端队列的链表实现 3.双端队列的数组实现 4.优先队列无序数组实现 5.阻塞队列 6.总结 1.队列拓展概述 首先来看一张图&#xff0c;来大致了解一下他们的…

解决SpringMVC在JSP页面取不到ModelAndView中数据

版权声明 本文原创作者&#xff1a;谷哥的小弟作者博客地址&#xff1a;http://blog.csdn.net/lfdfhl 问题描述 ModelAndView携带数据跳转到指定JSP页面后在该页面通过EL表达式取不到原本存放在ModelAndView中的数据。 问题原因 在IDEA中创建Maven工程时web.xml中默认的约束…

QT用户登录注册,数据库实现

登录窗口头文件 #ifndef LOGINUI_H #define LOGINUI_H#include <QWidget> #include <QLineEdit> #include <QPushButton> #include <QLabel> #include <QMessageBox>#include <QSqlDatabase> //数据库管理类 #include <QSqlQuery> …

滚雪球学Java(40):解读Java面向对象编程中的方法和继承,打造可维护的代码库

&#x1f3c6;本文收录于「滚雪球学Java」专栏&#xff0c;专业攻坚指数级提升&#xff0c;助你一臂之力&#xff0c;带你早日登顶&#x1f680;&#xff0c;欢迎大家关注&&收藏&#xff01;持续更新中&#xff0c;up&#xff01;up&#xff01;up&#xff01;&#xf…

Ajax学习笔记

目录 Ajax介绍Ajax概述同步异步 原生Ajax演示AxiosAxios的基本使用Axios快速入门Axios请求方法别名Axios案例 Ajax介绍 Ajax概述 我们前端页面中的数据应该来自于后台&#xff0c;那么我们的后台和前端是互不影响的2个程序&#xff0c;那么我们前端应该如何从后台获取数据呢&…