设计存储过程S_C_SC,求出某课程的考试学生姓名和成绩;并执行验证
时间: 2024-05-15 15:13:01 浏览: 76
假设有三个表:学生表(S),课程表(C),成绩表(SC),其中成绩表SC关联了学生表S和课程表C,可以设计如下的存储过程S_C_SC来查询某门课程的考试学生姓名和成绩:
```
CREATE PROCEDURE S_C_SC
@courseName NVARCHAR(50)
AS
BEGIN
SELECT S.name, SC.score
FROM SC
INNER JOIN S ON SC.student_id = S.id
INNER JOIN C ON SC.course_id = C.id
WHERE C.course_name = @courseName
END
```
此存储过程接受一个参数@courseName,表示要查询的课程名称。在存储过程中,使用INNER JOIN将成绩表SC、学生表S和课程表C进行关联,以便查询出某门课程的考试学生姓名和成绩。最后,根据@courseName参数进行筛选,只返回指定课程的学生信息。
要验证该存储过程是否正确,可以执行如下SQL语句:
```
EXEC S_C_SC '数学'
```
该语句将查询数学课程的所有学生的成绩和姓名,并将结果返回。如果结果符合预期,说明存储过程设计正确。
相关问题
一.针对教学管理数据库ST,创建下列存储过程并执行: Student(Sno,Sname, Ssex, Sage,Sdept) SC(Sno,Cno,Grade) C(Cno,Cname,Cpno,Ccredit) 1.创建名为s_grade的存储过程,要求查询每个学生各门课程的成绩,其中包括每个学生的sno,sname,cname,grade。 2.创建名为proc_exp的存储过程,要求输入某学生的姓名时从SC表中查询该学生的平均成绩。 3.创建名为s_info的存储过程,要求输入某学生的姓名时输出该学生所学课程的门数以及他的平均成绩。 4.创建存储过程proc_insert_sno,实现对sc表的数据的插入。 5.修改存储过程proc_exp,要求输入学生学号时根据该学生所选课程的成绩显示提示信息,即如果平均成绩成绩在60分以上,显示“此学生成绩合格,成绩为XX分”,否则显示“此学生综合成绩不合格,成绩为XX分”
好的,以下是对应的SQL语句:
1. 创建名为s_grade的存储过程,要求查询每个学生各门课程的成绩,其中包括每个学生的sno,sname,cname,grade。
```
CREATE PROCEDURE s_grade
AS
BEGIN
SELECT S.Sno, S.Sname, C.Cname, SC.Grade
FROM Student AS S
INNER JOIN SC ON S.Sno = SC.Sno
INNER JOIN C ON C.Cno = SC.Cno
ORDER BY S.Sno;
END
```
该存储过程会查询出每个学生各门课程的成绩,并按学生学号排序。注意,这里假设有如下表结构:
- Student表:包含学生信息,其中Sno是主键
- C表:包含课程信息,其中Cno是主键
- SC表:记录每个学生每门课程的成绩,其中Sno和Cno是外键,关联到Student和C表中的主键。同时,该表还包含Grade字段,表示学生在该门课程中的成绩。
2. 创建名为proc_exp的存储过程,要求输入某学生的姓名时从SC表中查询该学生的平均成绩。
```
CREATE PROCEDURE proc_exp
@Sname VARCHAR(20)
AS
BEGIN
SELECT AVG(SC.Grade) AS Avg_Grade
FROM Student AS S
INNER JOIN SC ON S.Sno = SC.Sno
WHERE S.Sname = @Sname;
END
```
该存储过程会根据输入的学生姓名查询该学生在所有课程中的平均成绩。
3. 创建名为s_info的存储过程,要求输入某学生的姓名时输出该学生所学课程的门数以及他的平均成绩。
```
CREATE PROCEDURE s_info
@Sname VARCHAR(20)
AS
BEGIN
SELECT COUNT(*) AS Course_Num, AVG(SC.Grade) AS Avg_Grade
FROM Student AS S
INNER JOIN SC ON S.Sno = SC.Sno
WHERE S.Sname = @Sname;
END
```
该存储过程会根据输入的学生姓名查询该学生所学课程的门数以及平均成绩。
4. 创建存储过程proc_insert_sno,实现对sc表的数据的插入。
```
CREATE PROCEDURE proc_insert_sno
@Sno VARCHAR(10),
@Cno VARCHAR(10),
@Grade INT
AS
BEGIN
INSERT INTO SC(Sno, Cno, Grade)
VALUES (@Sno, @Cno, @Grade);
END
```
该存储过程会向SC表中插入一条数据,包括学生学号、课程编号和成绩。
5. 修改存储过程proc_exp,要求输入学生学号时根据该学生所选课程的成绩显示提示信息,即如果平均成绩在60分以上,显示“此学生成绩合格,成绩为XX分”,否则显示“此学生综合成绩不合格,成绩为XX分”
```
CREATE PROCEDURE proc_exp
@Sno VARCHAR(10)
AS
BEGIN
DECLARE @Avg_Grade FLOAT;
SELECT @Avg_Grade = AVG(Grade)
FROM SC
WHERE Sno = @Sno;
IF @Avg_Grade >= 60
PRINT '此学生成绩合格,成绩为' + CONVERT(VARCHAR(10), @Avg_Grade) + '分';
ELSE
PRINT '此学生综合成绩不合格,成绩为' + CONVERT(VARCHAR(10), @Avg_Grade) + '分';
END
```
该存储过程会根据输入的学生学号查询该学生在所有课程中的平均成绩,并根据平均成绩输出相应的提示信息。
创建存储过程stu_sc,查询出姓名为“李丽”的选课信息(学生学号,学生姓名,课程编号,课程名,成绩等信息),并执行存储过程
好的,以下是创建存储过程的 SQL 代码:
```
CREATE PROCEDURE stu_sc
AS
BEGIN
SELECT s.stu_id, s.stu_name, c.course_id, c.course_name, sc.score
FROM student s
JOIN score sc ON s.stu_id = sc.stu_id
JOIN course c ON c.course_id = sc.course_id
WHERE s.stu_name = '李丽';
END
```
请注意,这里的表名和字段名仅供参考,具体根据你的实际情况进行修改。
执行该存储过程的 SQL 代码如下:
```
EXECUTE stu_sc;
```
执行后,即可查询出姓名为“李丽”的选课信息。
阅读全文