MySQL数据库基础练习系列——教务管理系统
项目名称与项目简介
教务管理系统是一个旨在帮助学校或教育机构管理教务活动的软件系统。它涵盖了学生信息管理、教师信息管理、课程管理、成绩管理以及相关的报表生成等功能。通过该系统,学校可以更加高效地处理教务数据,提升教学质量和管理水平。
1.新建ER图表和数据库模型图。
Chen's 数据库表示法——ER图绘制使用形
Crow's Foot数据库表示法——数据库模型图使用形状
2.DDL和DML语句
DDL语句
CREATE TABLE Users (user_id INT AUTO_INCREMENT PRIMARY KEY COMMENT '用户ID',username VARCHAR(50) NOT NULL UNIQUE COMMENT '用户名',password VARCHAR(255) NOT NULL COMMENT '密码',gender ENUM('男', '女') NOT NULL COMMENT '性别',email VARCHAR(100) UNIQUE COMMENT '邮箱',phone VARCHAR(20) NOT NULL COMMENT '手机号',address VARCHAR(200) NOT NULL COMMENT '地址'
);CREATE TABLE Roles (role_id INT AUTO_INCREMENT PRIMARY KEY COMMENT '角色ID',role_name VARCHAR(50) NOT NULL UNIQUE COMMENT '角色名称'
);CREATE TABLE `userroles` (`user_id` int(11) NOT NULL COMMENT '用户ID',`role_id` int(11) NOT NULL COMMENT '角色ID',`userroles_id` int(8) NOT NULL AUTO_INCREMENT,PRIMARY KEY (`userroles_id`) USING BTREE,KEY `role_id` (`role_id`)
) ENGINE=InnoDB AUTO_INCREMENT=4 DEFAULT CHARSET=utf8;CREATE TABLE Courses (course_id INT AUTO_INCREMENT PRIMARY KEY COMMENT '课程ID',course_name VARCHAR(100) NOT NULL UNIQUE COMMENT '课程名称',course_code VARCHAR(50) NOT NULL UNIQUE COMMENT '课程代码',teacher_id INT NOT NULL UNIQUE COMMENT '教师ID',credit DECIMAL(3,1) NOT NULL COMMENT '学分',description TEXT COMMENT '课程描述'
);CREATE TABLE Teachers (teacher_id INT AUTO_INCREMENT PRIMARY KEY COMMENT '教师ID',user_id INT NOT NULL COMMENT '关联的用户ID',subject VARCHAR(100) NOT NULL COMMENT '教学科目',qualification VARCHAR(255) COMMENT '教师资质',teacherPhone VARCHAR(20) NOT NULL COMMENT '教师手机号',gender ENUM('男', '女') NOT NULL COMMENT '性别',FOREIGN KEY (user_id) REFERENCES Users(user_id)
);CREATE TABLE Students (student_id INT AUTO_INCREMENT PRIMARY KEY COMMENT '学生ID',user_id INT NOT NULL COMMENT '关联的用户ID',class VARCHAR(50) NOT NULL COMMENT '班级',year_of_entry YEAR NOT NULL COMMENT '入学年份',gender ENUM('男', '女') NOT NULL COMMENT '性别',phone VARCHAR(20) NOT NULL COMMENT '手机号',address VARCHAR(200) NOT NULL COMMENT '地址',FOREIGN KEY (user_id) REFERENCES Users(user_id)
);CREATE TABLE Grades (grade_id INT AUTO_INCREMENT PRIMARY KEY COMMENT '成绩ID',student_id INT NOT NULL COMMENT '学生ID',course_id INT NOT NULL COMMENT '课程ID',grade DECIMAL(5, 2) NOT NULL COMMENT '成绩',FOREIGN KEY (student_id) REFERENCES Students(student_id),FOREIGN KEY (course_id) REFERENCES Courses(course_id)
);
DML语句
-- Users 表
INSERT INTO Users (username, password, gender, email, phone, address)
VALUES('甄嬛', '123', '女', 'zhenhuan@example.com', '1234567890', '河北'),('雍正', '456', '男', 'yongzheng@example.com', '0987654321', '山东'),('苏培盛', '789', '男', 'supershy@example.com', '1122334455', '河北'),('年世兰', '121', '女', 'nianshilan@example.com', '5544332211', '四川'),('允礼', '113', '男', 'yunli@example.com', '6677889900', '上海'),('沈眉庄', '125', '女', 'shenmeizhuang@example.com', '0099887766', '贵州'),('安陵容', '486', '女', 'anlingrong@example.com', '1357924680', '山东'),('乌兰那拉·宜修', '女', '女', 'yixiu@example.com', '0246813579', '重庆'),('温实初', '415', '男', 'win10chu@example.com', '9876543210', '河北'),('浣碧', '785', '女', 'huanbi@example.com', '0123456789', '河北');-- Roles 表
INSERT INTO roles VALUES(0,'学生1');
INSERT INTO roles VALUES(0,'教师2');
INSERT INTO roles VALUES(0,'管理员3');-- UserRoles 表
INSERT INTO UserRoles (user_id, role_id) VALUES
(1, 1), -- 管理员
(2, 2), -- 教师
(3, 3); -- 学生-- Courses 表
INSERT INTO Courses (course_name, course_code, teacher_id, credit, description)
VALUES('数学', 'MAT101', 1, 2.5, '基础数学课程'),('英语', 'ENG101', 2, 3.0, '基础英语课程'),('物理', 'PHY101', 3, 4.0, '大学物理'),('化学', 'CHE101', 4, 2.0, '普通化学'),('计算机科学', 'CS101', 5, 4.5, '计算机入门'),('生物学', 'BIO101', 6, 1.0, '生物学基础'),('历史', 'HIS101', 7, 1.5, '世界历史'),('经济学', 'ECO101', 8, 3.5, '微观经济学'),('艺术史', 'ART101', 9, 5.0, '艺术发展历程'),('心理学', 'PSY101', 10, 5.5, '心理学导论');-- Teachers 表
INSERT INTO Teachers (user_id, subject, qualification, teacherPhone, gender)
VALUES(1, '数学', '博士', '1111111111', '男'),(2, '英语', '硕士', '2222222222', '女'),(3, '物理', '教授', '3333333333', '男'),(4, '化学', '副教授', '4444444444', '女'),(5, '计算机科学', '专家', '5555555555', '男'),(6, '生物学', '博士', '6666666666', '女'),(7, '历史', '教授', '7777777777', '男'),(8, '经济学', '硕士', '8888888888', '女'),(9, '艺术史', '专家', '9999999999', '男'),(10, '心理学', '博士', '0000000000', '女');-- Students 表
INSERT INTO Students (user_id, class, year_of_entry, gender, phone, address)
VALUES(1, '一班', 2023, '男', '1122334455', 'address11'),(2, '二班', 2022, '女', '2233445566', 'address12'),(3, '三班', 2021, '男', '3344556677', 'address13'),(4, '四班', 2020, '女', '4455667788', 'address14'),(5, '五班', 2019, '男', '5566778899', 'address15'),(6, '六班', 2018, '女', '6677889900', 'address16'),(7, '七班', 2017, '男', '7788990011', 'address17'),(8, '八班', 2016, '女', '8899001122', 'address18'),(9, '九班', 2015, '男', '9900112233', 'address19'),(10, '十班', 2014, '女', '0011223344', 'address20');-- Grades 表
INSERT INTO Grades (student_id, course_id, grade) VALUES
(1, 1, 90.00),
(1, 2, 85.00),
(2, 3, 88.00),
(2, 4, 87.00),
(7, 8, 99.00),
(8, 9, 88.00),
(9, 10,85.00),
(4, 6, 75.00),
(5, 2, 100.00),
(6, 9, 99.00);
3.简单查询与多表联合复杂查询。
-- 简单查询:查询所有用户的信息,仅显示用户的姓名,性别和手机号,用中文显示列名
SELECT username '用户姓名', gender '性别', phone '手机号' FROM users;-- 复杂查询:查询2020 年入学的学生的成绩信息
SELECT s.student_id '学生id', s.class '班级', g.course_id '课程id', g.grade '成绩'
FROM Students s
JOIN Grades g ON s.student_id = g.student_id
WHERE s.year_of_entry = 2020; -- 使用 WHERE 子句筛选出入学年份为 2020 年的学生
/*
上述查询首先使用 JOIN 操作将 Students 表和 Grades 表基于 student_id 进行关联。
然后通过 WHERE 子句指定条件,只选取入学年份为 2020 年的学生的相关记录。
最后选择要显示的列,包括学生 ID、所在班级、课程 ID 和成绩。
*/
运行结果
4.触发器
触发器1: 当在Students
表中插入新记录时,在Grades
表中为新学生添加默认课程的成绩。
DELIMITER //
CREATE TRIGGER after_student_insert
AFTER INSERT ON Students
FOR EACH ROW
BEGININSERT INTO Grades (student_id, course_id, grade)VALUES (NEW.student_id, 1, 0.00);
END;
//
DELIMITER ;
测试语句1:在学生表中插入新学生时,自动在Grades
表中为这些学生添加默认的course_id
为1的课程的成绩(假设为0)。
-- 测试语句
INSERT INTO Students (user_id, class, year_of_entry, gender, phone, address)
VALUES (11, '十一班', 2024, '男', '12345678901', '测试地址');-- 检查是否成功在Grades表中插入了对应学生的记录
SELECT * FROM Grades WHERE student_id = 11;
测试结果1:
触发器2: 当尝试更新Grades
表中的成绩时,如果成绩超过100或小于0,则阻止更新。
DELIMITER //
CREATE TRIGGER before_grade_update
BEFORE UPDATE ON Grades
FOR EACH ROW
BEGINIF NEW.grade > 100 OR NEW.grade < 0 THENSIGNAL SQLSTATE '45000' SET MESSAGE_TEXT = '成绩必须在0到100之间!';END IF;
END;
//
DELIMITER ;
测试语句2:当修改学生成绩时,如果成绩超过100或小于0,则阻止更新
-- 测试语句(尝试将成绩更新为101,应该失败)
UPDATE Grades SET grade = 101 WHERE student_id = 1 AND course_id = 1;
测试结果2
触发器3:确保插入Users
表的用户具有唯一的用户名和邮箱
DELIMITER //
CREATE TRIGGER trg_check_user_unique
BEFORE INSERT ON Users
FOR EACH ROW
BEGINIF EXISTS (SELECT 1 FROM Users WHERE username = NEW.username OR email = NEW.email) THENSIGNAL SQLSTATE '45000' SET MESSAGE_TEXT = 'Username or email already exists';END IF;
END //
DELIMITER ;
测试语句3:尝试插入一个已存在的用户名或邮箱应该会导致错误。
INSERT INTO Users (username, password, gender, email, phone, address)
VALUES ('甄嬛', 'new_password', '女', 'zhenhuan@example.com', '12345678901', '新地址'); -- 这会失败,因为用户名已存在
测试结果3:
5.存储过程它用于向Grades
表中插入一条新的成绩记录
DELIMITER //
CREATE PROCEDURE InsertGrade(IN p_student_id INT,IN p_course_id INT,IN p_grade DECIMAL(5, 2)
)
BEGIN-- 检查参数是否有效IF p_student_id IS NULL OR p_course_id IS NULL OR p_grade IS NULL THENSIGNAL SQLSTATE '45000' SET MESSAGE_TEXT = 'Invalid input. All parameters must be provided.';END IF;-- 插入成绩INSERT INTO Grades (student_id, course_id, grade)VALUES (p_student_id, p_course_id, p_grade);-- 如果需要,可以在这里添加其他逻辑,比如检查是否已经存在相同的成绩记录等-- 返回结果SELECT 'Grade inserted successfully.' AS message;
END //
DELIMITER ;
测试语句:插入操作使用INSERT INTO ... VALUES
语句。插入后,可以选择性地添加其他逻辑,比如检查是否已经存在相同的成绩记录。最后,它返回一个表示成功的消息。
-- 调用存储过程插入一个新的成绩记录
CALL InsertGrade(11, 1, 95.00); -- 假设有一个学生ID为11的学生和课程ID为1的课程-- 查询Grades表以验证是否插入成功
SELECT * FROM Grades WHERE student_id = 11 AND course_id = 1;
测试结果
相关文章:
MySQL数据库基础练习系列——教务管理系统
项目名称与项目简介 教务管理系统是一个旨在帮助学校或教育机构管理教务活动的软件系统。它涵盖了学生信息管理、教师信息管理、课程管理、成绩管理以及相关的报表生成等功能。通过该系统,学校可以更加高效地处理教务数据,提升教学质量和管理水平。 1.…...
windowns server2016服务器配置php调用powerpoint COM组件
解决问题:windowns server2016服务器配置php调用powerpoint COM组件 环境: windows server2016 宝塔(nginxmysqlphp7.2) IIS 搭建宝塔: 下载地址:https://www.bt.cn/download/windows.html 安装使用&…...
Git之checkout/reset --hard/clean -f区别(四十二)
简介: CSDN博客专家,专注Android/Linux系统,分享多mic语音方案、音视频、编解码等技术,与大家一起成长! 优质专栏:Audio工程师进阶系列【原创干货持续更新中……】🚀 优质专栏:多媒…...
MySQL数据库基础练习系列:科研项目管理系统
DDL CREATE TABLE Users (user_id INT AUTO_INCREMENT PRIMARY KEY COMMENT 用户ID,username VARCHAR(50) NOT NULL UNIQUE COMMENT 用户名,password VARCHAR(255) NOT NULL COMMENT 密码,gender ENUM(男, 女) NOT NULL COMMENT 性别,email VARCHAR(100) UNIQUE COMMENT 邮箱 …...
算法设计与分析--考试真题
分布式算法试题汇总选择题简答题算法题 2013级试题2019级试题2021年秋考卷 根据考试范围找相应题目做。 分布式算法试题汇总 选择题 下述说法错误的是___ A 异步系统中的消息延迟是不确定的 B 分布式算法的消息复杂性是指在所有合法的执行上发送消息总数的最大值 C 在一个异步…...
【鸿蒙学习笔记】页面和自定义组件生命周期
官方文档:页面和自定义组件生命周期 目录标题 [Q&A] 都谁有生命周期? [Q&A] 什么是组件生命周期? [Q&A] 什么是组件?组件生命周期 [Q&A] 什么是页面生命周期? [Q&A] 什么是页面?页面生…...
ASPICE与ISO 21434:汽车软件与网络安全标准的协同与互补
ASPICE(Automotive SPICE)与ISO 21434在汽车行业中存在显著的相关性,主要体现在以下几个方面: 共同目标: ASPICE和ISO 21434都旨在提高汽车系统和软件的质量、可靠性和安全性。ASPICE关注汽车软件开发过程的成熟度和…...
视频格式转换方法:如何使用视频转换器软件转换视频
众所周知,目前存在许多不同的视频和音频格式。但我们的媒体播放器、移动设备、PC 程序等仅兼容少数特定格式。例如,如果不先将其转换为 MP4、MOV 或 M4V 文件,AVI、WMV 或 MKV 文件就无法在 iPhone 上播放。 视频转换器允许您将一种视频格式…...
vim操作小诀窍:快速多行添加注释
在使用vim编译python代码的时候,经常碰到需要将一段代码注释的情况,每次都要按“向下” “向左”按钮,将光标移到句首,然后再键入#井号键。如果行数较多,则操作相当繁琐。 vim里面有将一段文字前面加#注释的方法&#…...
无线麦克风领夹哪个牌子好,2024年领夹麦克风品牌排行榜推荐
随着短视频热潮的兴起,越来越多的人倾向于用vlog记录日常生活,同时借助短视频和直播平台开辟了副业。在这一过程中,麦克风在近两年内迅速发展,从最初的简单收音功能演变为拥有多样款式和功能,以满足视频创作的需求。…...
Mybatis入门——语法详解:基础使用、增删改查、起别名、解决问题、注释、动态查询,从入门到进阶
文章目录 1.基础使用1.添加依赖2.在resouces文件下新建xml文件db.properties3.在resouces文件下新建xml文件mybatis-config-xml4.创建一个MybatisUtils工具类5.创建xml文件XxxMapper.xml映射dao层接口6.添加日志5.测试 2.增删改查1.select2.delete3.update4.insert5.模糊查询6.…...
仓库选址问题【数学规划的应用(含代码)】阿里达院MindOpt
本文主要讲述使用MindOpt工具优化仓库选址的数学规划问题。 视频讲解👈👈👈👈👈👈👈👈👈 一、案例场景 仓库选址问题在现代物流和供应链管理中具有重要的应用。因为仓库…...
Docker Compose 一键快速部署 RocketMQ
Apache RocketMQ是一个开源的分布式消息中间件系统,最初由阿里巴巴开发并贡献给Apache软件基金会。RocketMQ提供了高性能、高可靠性、高扩展性和低延迟的消息传递服务,适用于构建大规模分布式系统中的消息通信和数据同步。 RocketMQ支持多种消息模型&am…...
Vscode lanuch.json
Intro 使用launch.json 能够方便的运行需要传很多参数的代码文件 如下: import math import argparse # 1、导入argpase包def parse_args():parse argparse.ArgumentParser(descriptionCalculate cylinder volume) # 2、创建参数对象parse.add_argument(--rad…...
Golang开发:构建支持并发的网络爬虫
Golang开发:构建支持并发的网络爬虫 随着互联网的快速发展,获取网络数据成为了许多应用场景中的关键需求。网络爬虫作为一种自动化获取网络数据的工具,也因此迅速崛起。而为了应对日益庞大的网络数据,开发支持并发的爬虫成为了必…...
2024年跨境电商关键数据统计:市场规模将达到1.976万亿美元
预计2024年跨境电商消费市场规模将达到1.976万亿美元,占全球网上销售总额的31.2%。这一数据无疑展示了跨境电商市场的巨大潜力和迅猛增长趋势。 全球跨境电商的现状与未来 现状 2023年,全球跨境电商市场规模预计达到1.56万亿美元,占全球电子…...
联想至像M3070DNA打印机加粉及清零方法
基本参数: 产品类型:黑白激光多功能商用一体机(打印/复印/扫描) 网络功能:支持有线网络打印 最大处理幅面:A4 双面功能:自动 打印速度:30页/分钟(高速激光打印&…...
通过nginx去除 api url前缀 并保持后面剩余的url不变向后台请求
如 我前台浏览器向后台请求的接口是 http://127.0.0.1:5099/api/sample/sample/getbuttonlist 实际的请求接口传向 http://192.168.3.71:5099/sample/sample/getbuttonlist 方法是向config中加入下面这样一个server server {listen 5099;location /api/ {rewrite ^/a…...
AI技术在现代社会中的广泛应用及其影响
目录 前言: 一、AI技术在医疗领域的应用 二、AI技术在教育领域的应用 三、AI技术在工业领域的应用 四、AI技术在金融领域的应用 五、AI技术在生活领域的应用 前言: 随着科技的不断发展,人工智能(AI)技术逐渐成为人…...
VBA 批量变换文件名
1. 页面布局 在“main”Sheet中按照下面的格式编辑。 2. 实现代码 Private wsMain As Worksheet Private intIdx As LongPrivate Sub getExcelBookList(strPath As String)Dim fso As ObjectDim objFile As ObjectDim objFolder As ObjectSet fso = CreateObject("Scrip…...
OpenHarmony 5.0 纯血鸿蒙系统
OpenHarmony-v5.0-Beta1 版本已于 2024-06-20 发布。 OpenHarmony 5.0 Beta1 版本标准系统能力持续完善,ArkUI 完善了组件通过 C API 调用的能力;应用框架细化了生命周期管理能力,完善了应用拉起、跳转的能力;分布式软总线连接能力…...
计算机网络地址划分A-E(自学)
1、网络地址组成 (1)物理地址MAC(Media Access Control Address) 网卡生产商分配,全球唯一,48/64位二进制 (2)逻辑地址IP(Internet Protocol) 网络层地址,用于在不同网…...
js导入导出
好久没有学习新的知识点了,今天开始学一下前端的知识点。直接在vscode里面编写,然后从基本的前端知识开始。 JS的导入导出 <!DOCTYPE html> <html lang"en"><head><meta charset"UTF-8"><meta name"…...
python办公自动化之excel
用到的库:openpyxl 实现效果:读取单元格的值,写入单元格 代码: import openpyxl # 打开现有工作簿 workbookopenpyxl.load_workbook(现有工作簿.xlsx) # 选择一个工作表 sheetworkbook[交易表] # 读取单元格的值 cell_valueshe…...
生命在于学习——Python人工智能原理(2.5.1)
五、Python的类与继承 5.1 Python面向对象编程 在现实世界中存在各种不同形态的事物,这些事物之间存在各种各样的联系。在程序中使用对象来映射现实中的事物,使用对象之间的关系描述事物之间的联系,这种思想用在编程中就是面向对象编程。 …...
visual studio 2022配置和使用jsoncpp
下载 jsoncpp下载位置: GitHub - open-source-parsers/jsoncpp: A C library for interacting with JSON. 编译库 1、下载完成之后解压 2、在解压文件的makefiles文件下有个vs71,在vs71中有visual studio项目,不过这里的项目是visual stud…...
Spring Boot中的动态数据源切换
Spring Boot中的动态数据源切换 大家好,我是免费搭建查券返利机器人省钱赚佣金就用微赚淘客系统3.0的小编,也是冬天不穿秋裤,天冷也要风度的程序猿!今天,我们将探讨如何在Spring Boot中实现动态数据源切换的技术。动态…...
npm error code EUNSUPPORTEDPROTOCOL 解决
更换包管理工具 npm i -g pnpm pnpm install pnpm run dev 参考 https://blog.csdn.net/qq_42592823/article/details/137541827...
基于改进天鹰优化算法(IAO)优化支持向量机(SVM)数据分类预测(IAO-SVM)
改进天鹰优化算法(IAO)见:【智能优化算法】改进的AO算法(IAO)-CSDN博客 支持向量机(SVM)数据分类预测:基于支持向量机(SVM)的数据分类预测-CSDN博客 代码原理 基于改进天鹰优化算法(IAO)优化支持向量机(SVM…...
【数学建模】—【Python库】—【Numpy】—【学习】
目录 编辑 1. NumPy安装 2. ndarray对象 1. 创建ndarray 1.从列表或元组创建: 2.使用内置函数创建: 2. ndarray属性 3. 数组运算 1. 基本运算 2. 数学函数 3.统计函数 4. 数组索引与切片 1. 一维数组索引与切片 2.多维数组索引与切片 5.…...
自助建站系统官网/2023b站免费推广入口游戏
冲刺了一段时间发现能力不足而力不从心,或许当初开发Android会更好? 第九周所花时间约20个小时代码量1200多行博客量10篇(冲刺)了解到的知识点 1.yii2的views 2.yii2的controller 3.yii2的models 转载于:https://www.cnblogs.com/…...
网站建设公司shundeit/edm营销
作者:朱金灿 来源:http://blog.csdn.net/clever101/ 有些东西或许只有失去你才会发现它在你的生活有着重大影响,比如google搜索。现在基本可以肯定g.cn是我最常用的网站。就在前些日子,我和朋友讨论google退出的事,他…...
cms做视频网站/百度推广总部电话
环境:vs2013 语言:C语言 时间:2015年3月10日 功能:实现二进制文件的读写实例 #define _CRT_SECURE_NO_WARNINGS #include <stdio.h> #include <stdlib.h> #define FILENAME "d:/studentInfo" #define COUNT 5 typedef struct {char name[10];short Ma…...
塘沽做网站/在线数据分析工具
这篇文章主要为大家详细介绍了Java环境配置与编译运行的相关资料,具有一定的参考价值,感兴趣的小伙伴们可以参考一下 一、开篇 通过对之前Java之路的了解之后,相信初学者们都对Java有了一个比较深印象的了解了。但是事情不能总停留在理论层面…...
wordpress怎么绑定paypal/黄页88网官网
这款经典的文本编辑器提供了所有的基本功能和一些让你自定义你的体验的令人兴奋的功能。• 来源:linux.cn • 作者:Seth Kenlon • 译者:geekpi •(本文字数:1861,阅读时长大约:2 分钟)有了 XEDIT 、jEdit、…...