SQL-----STUDENT

【学生信息表】

【宿舍信息表】

【宿舍分配表】

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

sql代码

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:

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

【宿舍信息表】

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

sql 复制代码
INSERT INTO dormitories (building, room_number, capacity)  
VALUES ('2 号楼', '101', 2);  

【宿舍分配表】

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

sql 复制代码
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');  

注意:

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

sql 复制代码
% 连接 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 
相关推荐
科技小花3 小时前
数据治理平台架构演进观察:AI原生设计如何重构企业数据管理范式
数据库·重构·架构·数据治理·ai-native·ai原生
一江寒逸3 小时前
零基础从入门到精通MySQL(中篇):进阶篇——吃透多表查询、事务核心与高级特性,搞定复杂业务SQL
数据库·sql·mysql
D4c-lovetrain3 小时前
linux个人心得22 (mysql)
数据库·mysql
阿里小阿希4 小时前
CentOS7 PostgreSQL 9.2 升级到 15 完整教程
数据库·postgresql
荒川之神4 小时前
Oracle 数据仓库雪花模型设计(完整实战方案)
数据库·数据仓库·oracle
做个文艺程序员4 小时前
MySQL安全加固十大硬核操作
数据库·mysql·安全
不吃香菜学java4 小时前
Redis简单应用
数据库·spring boot·tomcat·maven
一个天蝎座 白勺 程序猿4 小时前
Apache IoTDB(15):IoTDB查询写回(INTO子句)深度解析——从语法到实战的ETL全链路指南
数据库·apache·etl·iotdb
不知名的老吴4 小时前
Redis的延迟瓶颈:TCP栈开销无法避免
数据库·redis·缓存
YOU OU4 小时前
三大范式和E-R图
数据库