mysql 创建一个存储过程,帮助学生完成一次选 课操作,要求每位学生的公共选修课程数量不能超过3,每门课程的学生数量不能超过40。
时间: 2024-03-25 18:41:44 浏览: 39
好的,以下是一个简单的 MySQL 存储过程,可以满足你的需求:
```
DELIMITER //
CREATE PROCEDURE select_course(IN student_id INT, IN course_id INT)
BEGIN
DECLARE selected_count INT;
DECLARE course_count INT;
-- 获取该学生已选课程数量
SELECT COUNT(*) INTO selected_count FROM course_selection WHERE student_id = student_id;
-- 如果已选课程数量超过了3,直接返回错误
IF selected_count >= 3 THEN
SELECT '该学生已选了3门课程,无法再选' AS result;
RETURN;
END IF;
-- 获取该课程已选学生数量
SELECT COUNT(*) INTO course_count FROM course_selection WHERE course_id = course_id;
-- 如果该课程已选学生数量超过了40,直接返回错误
IF course_count >= 40 THEN
SELECT '该课程已有40名学生选课,无法再选' AS result;
RETURN;
END IF;
-- 否则插入选课记录
INSERT INTO course_selection(student_id, course_id) VALUES(student_id, course_id);
SELECT '选课成功' AS result;
END //
DELIMITER ;
```
这个存储过程接受两个参数:学生ID和课程ID。首先它会查询该学生已选课程数量,如果已选课程数量超过了3,则返回错误信息;然后它会查询该课程已选学生数量,如果已选学生数量超过了40,则返回错误信息;否则就插入选课记录,返回选课成功信息。你可以根据需要修改存储过程以满足具体需求。