一.
1.输入以下代码,创建存储过程stu_info,执行时通过输入姓名,可以查询该姓名的学生的各科成绩。
DELIMITER @@
CREATE PROCEDURE stu_info(IN name CHAR(8))
BEGIN
SELECT s.学号,姓名,课程编号,分数 FROM student_info s,grade g
WHERE s.学号=g.学号 and 姓名=name;
END @@
使用CALL命令执行存储过程stu_info,其参数值为'张青平'。
DELIMITER ;
CALL stu_info('张青平');
2.使用studentsdb数据库中的student_info表、curriculum表、grade表。
(1)创建一个存储过程stu_grade,查询学号为0001的学生的姓名、课程名称、分数。
(2)调用存储过程stu_grade。
DELIMITER @@
CREATE PROCEDURE stu_grade()
BEGIN
SELECT 姓名,课程名称,分数 FROM student_info s,curriculum c,grade g
WHERE s.`学号`=g.`学号` AND c.`课程编号`=g.`课程编号` AND s.`学号`='0001';
end @@
DELIMITER ;
CALL stu_grade();
3.使用studentsdb数据库中的student_info表、curriculum表、grade表。
(1)创建存储过程stu_name,当任意输入一个学生的姓名时,查看其课程的最高分、最低分、平均分。
(2)调用存储过程stu_name。
(3)删除存储过程stu_name。
![](https://img2023.cnblogs.com/blog/3276461/202311/3276461-20231103102715531-243243379.png)
DELIMITER @@
CREATE PROCEDURE stu_name(IN name CHAR(8))
BEGIN
SELECT `姓名`,MAX(g.分数) 最高分,MIN(g.分数) 最低分,AVG(g.分数) 平均分 FROM student_info s,curriculum c,grade g
WHERE s.`学号`=g.`学号` AND c.`课程编号`=g.`课程编号` AND 姓名=name GROUP BY 姓名;
END @@
DELIMITER ;
CALL stu_name('张青平');
DROP PROCEDURE stu_name;
4.使用studentsdb数据库中的grade表。
(1)创建一个存储过程stu_g_r,当输入一个学生的学号时,通过返回输出参数获取该学生选修课程的门数。
(2)执行存储过程stu_g_r,输入学号0002。
(3)显示0002号学生的选课门数。
DELIMITER @@
CREATE PROCEDURE stu_g_r(IN cno CHAR(4),OUT num INT)
BEGIN
SELECT count(*) INTO num FROM grade WHERE 学号=cno;
end @@
DELIMITER ;
CALL stu_g_r('0002',@num);
SELECT @num;
Query OK, 0 rows affected (0.00 sec)
Query OK, 1 row affected (0.00 sec)
+------+
| @num |
+------+
| 5 |
+------+
1 row in set (0.19 sec)
5.使用studentsdb数据库中的curriculum表、grade表。
(1)创建一个存储函数num_func,统计指定课程名称的选课人数。
(2)执行存储函数num_func,查看“C语言程序设计”选课人数。
SET GLOBAL log_bin_trust_function_creators=1;
DELIMITER @@
CREATE FUNCTION num_func(cname VARCHAR(50))
RETURNS INT
BEGIN
DECLARE num INT;
SELECT COUNT(*) INTO num FROM grade g,curriculum c
WHERE g.课程编号=c.课程编号 AND c.课程名称=cname;
RETURN num;
END @@
DELIMITER ;
SELECT num_func('C语言程序设计');
6.使用studentsdb数据库中的curriculum表、grade表。
(1)创建一个存储函数avg_func,通过游标统计指定课程的平均分。
(2)执行存储函数avg_func,查看“C语言程序设计”课程平均分。
(3)删除存储函数avg_func。
DELIMITER @@
CREATE FUNCTION avg_func(cname VARCHAR(50))
RETURNS DECIMAL
BEGIN
DECLARE v_acg DECIMAL;
DECLARE avg_cur CURSOR FOR SELECT avg(分数) FROM grade g, curriculum c
WHERE g.课程编号 = c.课程编号 AND 课程名称 = cname;
OPEN avg_cur;
FETCH avg_cur INTO v_acg;
CLOSE avg_cur;
RETURN v_acg;
END @@
SELECT avg_func('C语言程序设计') 课程平均分;
DROP FUNCTION avg_func;
二、实验思考
1.存储函数和存储过程如何将运算结果返回给外界?
答:存储函数中,可以使用return语句来返回一个值,该值可以是任何数据类型。
在存储过程中,可以使用out参数来返回一个值,也可以使用select语句将结果集返回给调用者
2.存储函数有OUT参数、INOUT参数吗?
out参数:从存储过程内部传值给调用者。在存储过程内部,该参数初始值为 null,无论调用者是否给存储过程参数设置值。
inout参数:跟 out 类似,都可以从存储过程内部传值给调用者。不同的是调用者还可以通过 inout 参数传递值给存储过程。
3.使用游标的步骤
(1)声明游标,代码:declare 游标名 cursor for select 语句;
(2)打开游标,代码:open 游标;
(3)提取数据,使用fetch语句将游标工作区中的数据读取到变量中,代码:tetch 游标名 into 变量名1【,变量名2...】;
(4)关闭游标,代码:close 游标名;