当前位置: 首页 > news >正文

SQL-----STUDENT

【学生信息表】

【宿舍信息表】

【宿舍分配表】

为了相互关联,我们需要在表中添加外键。在宿舍分配表中添加用于关联学生信息表的外键 student_id,以及用于关联宿舍信息表的外键 dormitory_id

sql代码

-- 创建学生信息表 
CREATE TABLE students( id INT PRIMARY KEY AUTO_INCREMENT COMMENT '学生ID', name VARCHAR(30) NOT NULL COMMENT '学生姓名', student_number VARCHAR(20) NOT NULL COMMENT '学号', gender VARCHAR(2) NOT NULL COMMENT '学生性别', grade VARCHAR(4) NOT NULL COMMENT '年级', major VARCHAR(30) NOT NULL COMMENT '专业', phone_number VARCHAR(20) DEFAULT NULL COMMENT '联系方式' 
); -- 创建宿舍信息表 
CREATE TABLE `dormitories` ( `id` INT NOT NULL AUTO_INCREMENT COMMENT '宿舍ID', `building` VARCHAR(20) NOT NULL COMMENT '所属的楼栋', `room_number` VARCHAR(20) NOT NULL COMMENT '房间号', `capacity` INT NOT NULL COMMENT '容纳人数', PRIMARY KEY (`id`) 
) COMMENT='宿舍信息表'; -- 创建宿舍分配表 
CREATE TABLE dormitory_assignments(  id INT PRIMARY KEY AUTO_INCREMENT COMMENT '分配记录ID',  student_id INT NOT NULL COMMENT '学生ID',  dormitory_id INT NOT NULL COMMENT '宿舍ID',  grade VARCHAR(4) NOT NULL COMMENT '年级', major VARCHAR(30) NOT NULL COMMENT '专业',  check_in_time DATETIME DEFAULT NULL COMMENT '入住时间',  check_out_time DATETIME DEFAULT NULL COMMENT '退房时间',  FOREIGN KEY (student_id) REFERENCES students(id),  FOREIGN KEY (dormitory_id) REFERENCES dormitories(id)  
);  

插入示例:

【学生信息表】
插入一条学生信息,学号为 20230001,姓名为 张三,性别为 男,年级为 2,专业为 计算机科学与技术,联系方式为 13412345678: 


INSERT INTO students (name, student_number, gender, grade, major, phone_number)  
VALUES ('张三', '20230001', '男', '2', '计算机科学与技术', '13412345678');  

 【宿舍信息表】
插入一条宿舍信息,楼栋为 2 号楼,房间号为 101,容纳人数为 2:

INSERT INTO dormitories (building, room_number, capacity)  
VALUES ('2 号楼', '101', 2);  

【宿舍分配表】
插入一条宿舍分配记录,学生 ID 为 1,宿舍 ID 为 1,年级为 2,专业为 计算机科学与技术,入住时间为 2023-09-01,退房时间为 2024-02-28:

INSERT INTO dormitory_assignments (student_id, dormitory_id, grade, major, check_in_time, check_out_time)  
VALUES (1, 1, '2', '计算机科学与技术', '2023-09-01', '2024-02-28');  

注意:

在进行宿舍分配时,如果发现目标宿舍已经达到了容纳人数上限,则应该停止当前的分配操作,不再继续分配该宿舍。

% 连接 MySQL 数据库 
conn = database(database_name, user_name, password, 'com.mysql.cj.jdbc.Driver', url); % 查询宿舍的容纳人数和当前入住人数 
sql_query = ['SELECT da.capacity, COUNT(*) FROM dormitory_assignments AS da '... 'WHERE da.dormitory_id = ' num2str(dormitory_id) ' GROUP BY da.dormitory_id;']; 
results = exec(conn, sql_query); % 读取查询结果 
results = fetch(results); 
current_number = results.Data{1,2}; 
capacity = results.Data{1,1}; % 判断宿舍是否已满 
if current_number >= capacity disp('该宿舍已经满员,无法分配!'); return; 
end 
http://www.lryc.cn/news/230540.html

相关文章:

  • OpenCV入门——图像视频的加载与展示一些API
  • Control的Invoke和BeginInvoke
  • 什么是OpenCL?
  • AdaBoost:提升机器学习的力量
  • Pikachu(皮卡丘靶场)初识XSS(常见标签事件及payload总结)
  • 一则DNS被重定向导致无法获取MySQL连接处理
  • Vue3中如何使用this
  • 7.jvm对象内存布局
  • U-boot(一):Uboot命令和tftp
  • 代码随想录算法训练营第五十三天丨 动态规划part14
  • pdf增强插件 Enfocus PitStop Pro 2022 mac中文版功能介绍
  • uniapp app tabbar 页面默认隐藏
  • 深度学习 YOLO 实现车牌识别算法 计算机竞赛
  • 即时通讯技术文集(第23期):IM安全相关文章(Part12) [共15篇]
  • 为什么UI自动化难做?—— 关于Selenium UI自动化的思考
  • Python小白之“没有名称为xlwings‘的模块”
  • RK3588 学习教程1——获取linux sdk
  • 保护您的Google账号安全:检查和加固措施
  • 「Verilog学习笔记」优先编码器Ⅰ
  • java实现TCP通信(socket)服务端-客户端
  • 企业信息模糊搜索API的使用及应用场景
  • .net6+aspose.words导出word并转pdf
  • 深度学习 植物识别算法系统 计算机竞赛
  • 《深入浅出进阶篇》洛谷P4147 玉蟾宫——悬线法dp
  • 社区论坛小程序源码系统,功能齐全,页面简洁,前端+后端+完整部署教程
  • 大数据开发面试(一)
  • softmax的高效CUDA编程和oneflow实现初步解析
  • 如何解决 Node.js 20 升级中未预期的请求问题
  • no tests were found
  • 泛型擦除是什么