在gradem数据库中创建存储过程proc_1,要求实现如下功能:存在不及格情况的学生选课情况列表,其中包括学号、姓名、性别、课程号、课程名、成绩、系别等。调用proc_1存储过程,观察执行结果。
时间: 2023-07-10 15:05:54 浏览: 121
下面是创建存储过程proc_1的SQL代码:
```
CREATE PROCEDURE proc_1
AS
BEGIN
SELECT
s.student_id,
s.student_name,
s.gender,
c.course_id,
c.course_name,
g.grade,
d.department_name
FROM
student s
JOIN grade g ON s.student_id = g.student_id
JOIN course c ON g.course_id = c.course_id
JOIN department d ON s.department_id = d.department_id
WHERE
g.grade < 60
ORDER BY
s.student_id,
c.course_id;
END
```
这个存储过程会查询出存在不及格情况的学生选课情况列表,并显示学号、姓名、性别、课程号、课程名、成绩和系别等信息。我们可以通过执行以下语句来调用存储过程:
```
EXEC proc_1;
```
执行结果会显示所有存在不及格情况的学生选课情况列表,按照学号和课程号排序。
相关问题
② 在gradem数据库中创建存储过程proc_2,要求实现如下功能:查询存在不及格情况的学生选课情况列表,其中包括学号、姓名、性别、课程号、课程名、成绩、系别等。调用proc_2存储过程,观察执行结果。
在MySQL或者类似支持存储过程的数据库系统Gradem中,你可以使用以下步骤创建一个名为`proc_2`的存储过程,用于查询有不及格成绩的学生选课情况:
```sql
DELIMITER //
CREATE PROCEDURE proc_2()
BEGIN
SELECT s.sno AS 学号, s.name AS 姓名, s.gender AS 性别, c.course_id AS 课程号, c.course_name AS 课程名, c.score AS 成绩, d.department AS 系别
FROM students s
JOIN enrollments e ON s.sno = e.student_sno
JOIN courses c ON e.course_id = c.course_id
JOIN departments d ON c.department_id = d.department_id
WHERE c.score < 60; -- 及格线通常设为60分
END //
DELIMITER ;
-- 调用存储过程
CALL proc_2();
```
这个存储过程会返回所有成绩低于及格分数线(例如60分)的学生的信息,包括他们的学号、姓名、性别、课程号、课程名称以及他们所选课程的系别。
在db_school数据库中创建存储过程proc_2,要求实现如下功能:存在不及格情况的学生选课情况列表,其中包括学号、姓名、性别、课程号、课程名、成绩、系别等。调用proc_2存储过程,观察执行结果。
好的,以下是创建存储过程proc_2的SQL语句:
```
CREATE PROCEDURE proc_2
AS
BEGIN
SELECT s.sid, s.sname, s.ssex, c.cid, c.cname, sc.score, d.dname
FROM student s, course c, sc, department d
WHERE s.sid = sc.sid AND c.cid = sc.cid AND s.sdept = d.did AND sc.score < 60
ORDER BY s.sid, c.cid
END
```
这个存储过程会查询db_school数据库中存在不及格情况的学生选课情况列表,包括学号、姓名、性别、课程号、课程名、成绩、系别等信息。调用存储过程之后,会返回查询结果。
你可以使用以下代码调用存储过程:
```
EXEC proc_2
```
执行结果会显示出存在不及格情况的学生选课情况列表。
阅读全文