Qt学生管理系统(付源码)

Qt学生管理系统

  • 一、前言
    • 1.1 项目介绍
    • 1.2 项目目标
  • 2、需求说明
    • 2.1 功能性说明
    • 2.2 非功能性说明
  • 三、UX设计
    • 3.1 登录界面
    • 3.2 学生数据展示
    • 3.3 信息插入和更新
  • 三、架构说明
    • 3.1 客户端结构如下
    • 3.2 数据流程图
      • 3.2.1 数据管理
      • 3.2.2 管理员登录
  • 四、 设计说明
    • 3.1 数据库设计
    • 3.2 结构设计
      • 3.2.1 通用结构
        • 3.2.1.1 student结构
        • 3.2.1.2 usr 结构
        • 3.2.1.3 audit_logs 结构
    • 3.2 接口结构
      • 3.2.1 StudentListRequest 学生信息列表请求
      • 3.2.2 StudentListRequest 学生信息列表响应
      • 3.2.3 LoginRequest 登录请求
      • 3.2.4 LoginResponse 登录响应
      • 3.2.5 AuditLogsRequest 审计请求
    • 3.3 接口说明
      • 3.3.1 学生相关接口
        • 3.3.1 添加用学生信息
        • 3.3.2 删除学生信息
        • 3.3.3 更新学生信息
        • 3.3.4 查询
      • 3.3.2 登录相关
        • 3.3.2.1 登录请求
      • 3.3.3 审计相关
        • 3.3.31 添加审计日志
  • 四、部署
    • 4.1 部署概述
    • 4.2 部署步骤
  • 五、源码地址:

一、前言

1.1 项目介绍

随着教育信息化的推进,学生管理系统成为学校管理的重要工具。传统的学生管理方式效率低、易出错,且难以满足现代化教育的需求。基于此,开发了一款基于 Qt 和 MySQL 的学生管理系统,以提高学校管理的效率和准确性。

1.2 项目目标

学生管理系统旨在为学校提供一个高效、可靠的学生信息管理平台,主要目标包括:

  • 提高学生信息管理的效率
  • 实现学生数据的安全存储和便捷访问
  • 提供多样化的查询和统计功能
  • 支持用户权限管理,确保数据安全

2、需求说明

2.1 功能性说明

  • 1.1 管理员登陆

    • 提供管理员登陆界面,登陆成功后才允许管理学生信息。
    • 账号输入框:输入最大长度为16,,只能输入字母和数字。
    • 密码输入框:密码长度小于6时提示错误,输入最大长度16。
  • 1.2 学生添加

    • 添加用学生信息,学生信息包括以下内容:
    • 名字、性别、电话、身份证、地址、微信号、QQ号
  • 1.3 学生展示

    • 以列表形式展示学生信息,展示学生的学号,性别,名字电话。
    • 支持翻页,每页展示10条数据,支持上一页/下一页,直接跳转指定页码,展示总页数和当前页。
  • 1.4 学生查询

    • 根据学生学号
    • 根据学生名字模糊查询
    • 根据学生性别查询
    • 根据学生生日范围查询
    • 根据学生电话号码查询
  • 1.5 学生信息修改

    • 可以修改除学号外的任何信息
  • 1.6 删除学生信息

    • 使用软删除
  • 1.7 审计日志

    • 记录添加用户信息,操作

2.2 非功能性说明

  • 输入框:做sql过滤,防止SQL注入获取用户账号密码。
  • 数据库存储密码时,使用安全存储,sha256(密码+安全码)
  • 数据库信息通过文件配置方式,可以使得程序部署方便。

三、UX设计

3.1 登录界面

在这里插入图片描述
密码框在输入的使用应该隐藏数据输入内容。

3.2 学生数据展示

在这里插入图片描述

3.3 信息插入和更新

在这里插入图片描述

三、架构说明

3.1 客户端结构如下

  • 客户端采用经典的MVC架构。
    • M:数据模型层,用于访问Mysql数据库
    • V:试图层,用于界面的展示。
    • C:控制层,用于业务处理(这里是完整项目,项目比较简单其实这个层会体现不出来。)
      在这里插入图片描述

3.2 数据流程图

3.2.1 数据管理

以下图数据流程图,通过这个图我们可以知道数据从界面到数据库,以及数据库数据到界面的整体流程

view层 contoller层 model层 DB 请求数据 参数判断,基本逻辑错里 参数错误 界面显示参数错误 数据请求 数据业务管理 数据库请求 返回数据 返回结果 业务处理 数据返回 展示数据 view层 contoller层 model层 DB

3.2.2 管理员登录

管理员的登录流程,也是上面2.3.1中的流程的具体使用,整体框架都是对标2.3.1

登录界面(view) 管理员控制器(controller) 管理员数据模型(model) 提交用户账户密码 根据用户名称查询用户的信息 返回查询结果 对比用户输入密码和数据查询密码是否一致 返回查询结果 登录界面(view) 管理员控制器(controller) 管理员数据模型(model)

四、 设计说明

3.1 数据库设计

表名:student

字段类型是否必填备注
idint学生学生号,主键
namevarchar(255)学生名字
sexvarchar(10)性别,男OR女
sfzvarchar(20)身份证,唯一值
telvarchar(20)电话号码
addressvarchar(255)学生地址
weixinvarchar(255)微信号
QQvarchar(255)qq号
statusvarchar(100)默认状态为active, active
create_timeTIMESTAMP创建时间,使用时间戳记录
create_byvarchar(100)创建用户
update_timeTIMESTAMP更新时间,使用时间戳记录
update_byvarchar(100)更新学生信息的用户
CREATE TABLE IF  NOT EXISTS student(
    id INT  NOT NULl PRIMARY KEY AUTO_INCREMENT,
    name VARCHAR(255) NOT NULL COMMENT  "学生名字",
    sex VARCHAR(10) NOT NULL COMMENT  "学生性别",
    sfz VARCHAR(20)  NOT NULL UNIQUE COMMENT  "身份证",
    tel VARCHAR(20) NOT NULL COMMENT  "电话号码",
    address VARCHAR(20) NOT NULl COMMENT  "学生地址",
    weixin VARCHAR(255)   COMMENT  "微信号",
    QQ VARCHAR(255) COMMENT  "qq号",
    status VARCHAR(100) NOT NULl COMMENT  "qq号",
    create_time  TIMESTAMP DEFAULT CURRENT_TIMESTAMP NOT NULL  COMMENT  "创建时间",
    create_by VARCHAR(100) NOT NULL  COMMENT  "创建用户",
    update_time TIMESTAMP DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP  COMMENT  "创建时间",
    update_by VARCHAR(100) NOT NULL  COMMENT  "创建用户"
) ENGINE=InnoDB;

表名:manager

字段类型是否必填备注
idint管理员ID,主键
uservarchar(100)登陆账户
pwvarchar(100)密码
safety_codevarchar(10)安全码
CREATE TABLE IF NOT EXISTS manager(
    id INT  NOT NULl PRIMARY KEY AUTO_INCREMENT,
    user  VARCHAR(100) NOT NULL  COMMENT "登陆账户",
    pw  VARCHAR(100) NOT NULL  COMMENT "密码",
    safety_code  VARCHAR(10) NOT NULL  COMMENT "安全码"
)ENGINE=InnoDB;

表名:audit_logs 审计记录

字段类型是否必填备注
idint管理员ID,主键
optionvarchar(100)操作类型,update,delete,insert
detailvarchar(1024)操作日志
create_byvarchar(100)操作管理员名称
create_timeTIMESTAMP创建时间
CREATE TABLE IF NOT EXISTS audit_logs(
    id INT  NOT NULl PRIMARY KEY AUTO_INCREMENT,
    option VARCHAR(100) NOT NULL  COMMENT "操作类型",
    detail VARCHAR(1024) NOT NULL  COMMENT "操作管理员名称",
    create_by  VARCHAR(100) NOT NULL  COMMENT "登陆账户",
    create_time  TIMESTAMP DEFAULT CURRENT_TIMESTAMP NOT NULL  COMMENT  "创建时间"
)ENGINE=InnoDB;

3.2 结构设计

3.2.1 通用结构

3.2.1.1 student结构
stuct Student{
    int id,
    QString name,
    QString sex,
    QString sfz,
    QString tel,
    QStrnig address,
    QString weixin,
    QString qq,
    QString status,
    QString create_time,
    QString create_by,
    QString update_time,
    QString update_by
};
3.2.1.2 usr 结构
stuct User{
    int id,
    QString user,
    QString pw;
    QString safety_code
} ;
3.2.1.3 audit_logs 结构
struct AuditLogs{
    int id ,    
    QString option, 
    QString detail,
    QString create_by,
    QString create_time
}

3.2 接口结构

3.2.1 StudentListRequest 学生信息列表请求

struct StudentListRequest{
    int page,       // 当前页码             必填
    int size,       // 每一页的数量         必填
    QString id,     // 查询请求的id         非必填
    QString name,   // 查询请求用户名       非必填
    QString sex,    // 查询请求用户性别     非必填
    QString sfz,    // 查询请求身份证       非必填
    QString weixin, // 查询请求微信号       非必填
    QString qq      // 查询请求QQ号         非必填
};

3.2.2 StudentListRequest 学生信息列表响应

struct StudentListResponse{
    int msg_code,                // 请求状态,0表示成功,其他表示错误
    QString msg,                 // 请求错误信息
    int current,                 // 当前页
    int total,                   // 请求数据的总数
    vector<Student> vecStudent   // 学生数据
};

3.2.3 LoginRequest 登录请求

struct LoginRequest{
    QString user;       // 用户账号 必填
    QString pw;         // 用户名称
};

3.2.4 LoginResponse 登录响应

struct LoginResponse{
    int msg_code,
    QString msg,
    QString user,
    QString loginTime
};

3.2.5 AuditLogsRequest 审计请求

struct AuditLogsRequest{
    QString option,
    QString detail,
    QString createBy
};

3.3 接口说明

接口表示view层与controller层的对接接口,view层只需要通过controller层的接口调用获取数据,剩下展示的内容有view层进行展示。

3.3.1 学生相关接口

view和controller对接的接口

3.3.1 添加用学生信息

bool addStudentInfo(Student info);

 QString sql = QString("insert into student (name,sex,sfz,tel,address,weixin,qq,status,create_by) "
            "values ('%0','%1','%2','%3','%4','%5','%6','%7','%8');")
            .arg(info.name)
            .arg(info.sex)
            .arg(info.tel)
            .arg(info.address)
            .arg(info.weixin)
            .arg(info.qq)
            .arg(QString::number(1))
            .arg("test");

    QSqlQuery query;
    if(!query.exec(sql)){
        qInfo()<<"init db data failed!"<<query.lastError()<< ":" << query.lastQuery();
        return Result(0,"");
    }
    return Result(0,"");
3.3.2 删除学生信息

bool deleteStudentInfo(int id);

3.3.3 更新学生信息

bool updateStudentInfo(int id,Student newInfo);

3.3.4 查询

StudentListResponse selectStudentList(StudentListRequest studentListRequest);

 StudentListResponse res;
    QString where  = getStudentListRequestWhere(studentListRequest);
    // 获取数据总数
    res.total = getCountSelectStudentList(studentListRequest);
    res.current = studentListRequest.page;
    res.msg_code = 0;
    QSqlQuery query;
    QString currentOffset = QString::number(studentListRequest.page * studentListRequest.size);
    QString strSize = QString::number(studentListRequest.size);

    QString sql = "select * from student " +where +"limit "+ currentOffset +","+ strSize;
    if(!query.exec(sql)){
        res.msg_code = -1;
        res.msg = query.lastError().text();
        return res;
    }
    qInfo()<<"last:" << query.lastQuery();
    // 处理查询结果
    while (query.next()) {
        Student stu;
        stu.id = query.value(0).toString();
        stu.name = query.value(1).toString();
        stu.sex = query.value(2).toString();
        stu.sfz  = query.value(3).toString();
        stu.tel =  query.value(4).toString();
        stu.address = query.value(5).toString();
        stu.weixin = query.value(6).toString();
        stu.qq  = query.value(7).toString();
        res.vecStudent.push_back(stu);
    }

    return res;

3.3.2 登录相关

3.3.2.1 登录请求

LoginResponse userLogin(LoginResponse loginResponse);


    if(pw.isNull() || pw.isEmpty()){
        return Result(LOGIN_ERROR_PASSWORD_EMPTY,LOGIN_ERROR_PASSWORD_EMPTY_MSG);
    }
    Result res(0,"");

    QSqlQuery query;
    query.clear();
    QString sql = QString("SELECT * FROM manager WHERE user = '%1'").arg(user);
    query.prepare(sql);
    qInfo() << query.lastQuery();
    if (!query.exec()) {
        qDebug() << "Error: Failed to insert student." << query.lastError();
        return res;
    }
    QString spw;
    while (query.next()) {
        int id = query.value("id").toInt();
       spw = query.value("pw").toString();
    }
    if(pw  == spw){
        return Result(LOGIN_OK,LOGIN_OK_MSG);
    }

    return Result(LOGIN_ERROR_PASSWORD,LOGIN_ERROR_PASSWORD_MSG);

3.3.3 审计相关

3.3.31 添加审计日志

void addAuditLogs(AuditLogsRequest auditLogsRequest);

四、部署

4.1 部署概述

该学生管理系统由 Qt 前端应用程序和 MySQL 数据库组成。Qt 应用程序通过读取配置文件 my.xml 连接到位于服务器上的 MySQL 数据库。

4.2 部署步骤

    1. 安装mysql数据库
    1. 导入初始化表init.sql
    1. 配置my.xml,配置文件需要和程序放在同一个目录中

五、源码地址:

https://gitcode.net/arv002/database/-/tree/master/StudentManagementSystem/StudentManagementSystem

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

unsupported_country_region_territory

最近调用chatgpt接口出现&#xff1a;unsupported_country_region_territory&#xff0c;Country, region, or territory not supported 翻译过来的大致意思就是

合宙 Air780E模块 AT 指令 MQTT连接

固件说明 重启模块 //tx ATRESET//rx ATRESETOK ^boot.romv!\n RDY^MODE: 17,17E_UTRAN ServiceCGEV: ME PDN ACT 1NITZ: 2024/07/10,08:33:440,0查询模块版本信息 //tx ATCGMR//rx ATCGMRCGMR: "AirM2M_780E_V1161_LTE_AT"OK基本流程 4G模块支持MQTT和MQTT SSl协…

某企业数据治理总体解决方案(45页PPT)

引言&#xff1a;集团企业数据治理总体解决方案旨在构建一个高效、安全、合规且灵活的数据管理体系&#xff0c;以支持企业决策优化、业务创新、风险管理和运营效率提升。该方案通过整合数据资源、规范数据流程、强化数据质量和促进数据共享&#xff0c;实现数据资产的最大化价…

Python task

def wordcount(text):# 将文本分割成单词列表&#xff0c;并转换为小写words text.lower().split()# 初始化一个空字典用于存储单词计数word_counts {}# 遍历单词列表中的每个单词for word in words:# 如果单词在字典中&#xff0c;则计数加1&#xff0c;否则将单词加入字典并…

Flutter跨平台开发技术

仅分享文字&#xff0c;见谅 Flutter Flutter 介绍 功能跨平台性架构流行度Flutter vs React Native 配置 Windows Flutter App 环境配置 Tizen Flutter App 环境用 Dart 语言开发 Flutter AppFlutter-Tizen 的限制 Flutter 介绍 Flutter 是由 Google 推出的开源移动应用开发…

“闭门造车”之多模态思路浅谈:自回归学习与生成

©PaperWeekly 原创 作者 | 苏剑林 单位 | 科学空间 研究方向 | NLP、神经网络 这篇文章我们继续来闭门造车&#xff0c;分享一下笔者最近对多模态学习的一些新理解。 在前文《“闭门造车”之多模态思路浅谈&#xff1a;无损》中&#xff0c;我们强调了无损输入对于理想的…

Qt中实现让静态图片动起来,创建动画效果

在现代应用程序开发中&#xff0c;动画效果是提升用户体验的重要元素之一。Qt作为一个强大的跨平台应用程序框架&#xff0c;提供了丰富的工具和库来创建各种动画效果。本文将介绍如何在Qt中使用静态图片创建动画效果。 实现方法一 使用QTimer和QPixmap 1.准备图片资源&#…

Diffusion model笔记

![在这里插入图片描述](https://i-blog.csdnimg.cn/direct/f5ec0915d48e4e17bf158b70296cc8d8.png stable diffusion

谷粒商城实战笔记-27-分布式组件-SpringCloud-Gateway-创建测试API网关

本节的主要内容是创建网关模块&#xff0c;将网关注册到Nacos&#xff0c;并配置路由进行测试。 一&#xff0c;创建网关模块 右键工程New->Module&#xff0c;创建新模块&#xff0c;模块名称 gulimall-gateway。 填充各种信息。 选中Gateway依赖。 点击Create创建模块。…

普中51单片机:定时器与计数器详解及应用(七)

文章目录 引言定时器工作原理TMOD定时器/计数器工作模式寄存器定时器工作模式模式0(13位定时器/计数器)模式1(16位定时器/计数器)模式2(8位自动重装模式)模式3(两个8位计数器) 定时器配置流程代码演示——LED1间隔1秒闪烁代码演示——按键1控制LED流水灯状态代码演示——LCD160…

企业数据治理做完了,如何让业务部门用起来

引言&#xff1a;企业数据治理完成后&#xff0c;确保业务部门能够充分利用这些数据并融入日常运营中&#xff0c;是实现数据价值最大化的关键步骤。以下是一些策略和建议&#xff0c;帮助推动业务部门使用数据治理成果&#xff1a; 一、管理层面推广 高层应用示范&#xff1…

【漏洞复现】方正全媒体采编系统——binary.do——SQL注入

声明&#xff1a;本文档或演示材料仅供教育和教学目的使用&#xff0c;任何个人或组织使用本文档中的信息进行非法活动&#xff0c;均与本文档的作者或发布者无关。 文章目录 漏洞描述漏洞复现测试工具 漏洞描述 方正全媒体采编系统&#xff08;FZMediaEditor&#xff09;是一…

网络安全第一次作业

需求 前置工作 给设备配好ip地址&#xff0c;并且在总公司处配置vlan 1&#xff0c; 先建立多个安全区域 接着新建两个策略 :办公区访问dmz区域策略&#xff0c;生产区访问dmz区域策略 2 &#xff0c; 不做配置即可&#xff0c;生产区本不允许访问互联网 3&#xff0c; 新…

学习大数据DAY14 PLSQL基础语法3

目录 二重循环 三种循环随便嵌套 exit continue return 作业 数据提取 游标 隐式游标 显示游标 动态游标 游标使用流程 游标属性 游标配合循环使用示例 作业2 参数游标 current of 语句 作业3 PLSQL基础语法&#xff08;三&#xff09; 二重循环 三种循环随便嵌…

LangChain框架详解

LangChain框架详解 LangChain是一个基于语言模型开发应用程序的强大框架&#xff0c;旨在帮助开发人员简化与大模型交互、数据检索以及将不同功能模块串联起来以完成复杂任务的过程。它提供了一套丰富的工具、组件和接口&#xff0c;使开发人员能够轻松构建上下文感知和具备逻…

Qt:19.浮动窗口/子窗口(子窗口介绍、代码方式创建子窗口、设置子窗口标题、为子窗口添加控件、设置子窗口停靠位置)

目录 1.子窗口介绍&#xff1a; 2.代码方式创建子窗口&#xff1a; 3.设置子窗口标题&#xff1a; 4.为子窗口添加控件&#xff1a; 5.设置子窗口停靠位置。 1.子窗口介绍&#xff1a; 在 Qt 中&#xff0c;可以创建和管理子窗口&#xff08;子窗口体&#xff09;以实现多窗…

线程安全(二)synchronized 的底层实现原理、锁升级

目录 一、基础使用1.1 不加锁的代码实现1.2 加锁的代码实现二、实现原理2.1 synchronized 简介2.2 对象监控器(Monitor)2.3 加锁过程第一步:判断 Owner 指向第二步:进入 EntryList 阻塞第三步:主动进入 WaitSet 等待三、锁升级3.1 对象的内存结构3.2 Mark Word 对象头3.3 …

python的简单爬取

需要的第三方模块 requests winr打开命令行输入cmd 简单爬取的基本格式&#xff08;爬取百度logo为例&#xff09; import requests url"http://www.baidu.com/img/PCtm_d9c8750bed0b3c7d089fa7d55720d6cf.png" resprequests.get(url)#回应 #保存到本地 with open(&…

地址翻译过程(TLB-->页表-->Cache-->主存-->外存)

目录 1.地址结构 2.查找快表或页表&#xff1a;从虚拟地址--->物理地址 3.通过物理地址访问数据 设某系统满足以下条件&#xff1a; •有一个TLB与一个data Cache •存储器以字节为编址单位 •虚拟地址 14位 •物理地址 12位 •页面大小为 64B •TLB 为四路组相联&#x…

嵌入式工程师从0开始,到底该学什么,怎么学?

作为嵌入式工程师&#xff0c;从零开始学习需要掌握以下几个关键方面。我收集归类了一份嵌入式学习包&#xff0c;对于新手而言简直不要太棒&#xff0c;里面包括了新手各个时期的学习方向编程教学、问题视频讲解、毕设800套和语言类教学&#xff0c;敲个22就可以免费获得。 基…