调用存储过程select_student_count输出学生人数;调用存储过程update_name ,将任意指定sno的学生姓名改为“余梅”
时间: 2023-07-14 10:13:27 浏览: 87
这里提供一个示例的存储过程实现:
```
-- 定义一个存储过程 select_student_count,用于查询学生人数
CREATE PROCEDURE select_student_count
AS
BEGIN
SELECT COUNT(*) AS student_count FROM student;
END;
-- 定义一个存储过程 update_name,用于修改学生姓名
CREATE PROCEDURE update_name
@sno CHAR(8) -- 指定学生的学号
AS
BEGIN
UPDATE student SET sname = '余梅' WHERE sno = @sno;
END;
```
通过执行 `EXEC select_student_count` 可以调用存储过程 `select_student_count` 并输出学生人数。
通过执行 `EXEC update_name '20210001'` 可以调用存储过程 `update_name` 并将学号为 `20210001` 的学生姓名修改为 `余梅`。
相关问题
mysql14. 创建存储过程 p_student,从student表中检索出所有电话以135开头的学生的学号、姓名、出生日期和电话等信息。 15. 创建存储过程pro_select(),用指定的学号和课程号为参数查询学生成绩,输出参数为学生平时成绩和结业成绩。 16. 创建一个存储过程 pro_insert(),向 score表中插入一行记录,然后创建另一存储过程pro_out(),调用存储过程pro_insert(),并查询输出score表中插入的记录。 17. 查看p_student存储过程的定义。
14. 创建存储过程 p_student:
```mysql
DELIMITER $$
CREATE PROCEDURE p_student()
BEGIN
SELECT sno, sname, birthday, phone
FROM student
WHERE phone LIKE '135%';
END $$
DELIMITER ;
```
15. 创建存储过程 pro_select():
```mysql
DELIMITER $$
CREATE PROCEDURE pro_select(IN student_id VARCHAR(10), IN course_id VARCHAR(10), OUT usual_score INT, OUT final_score INT)
BEGIN
SELECT usualscore, finalscore INTO usual_score, final_score
FROM score
WHERE sno = student_id AND cno = course_id;
END $$
DELIMITER ;
```
16. 创建一个存储过程 pro_insert(),向 score表中插入一行记录,然后创建另一存储过程pro_out(),调用存储过程pro_insert(),并查询输出score表中插入的记录。
```mysql
DELIMITER $$
CREATE PROCEDURE pro_insert(IN student_id VARCHAR(10), IN course_id VARCHAR(10), IN usual_score INT, IN final_score INT)
BEGIN
INSERT INTO score(sno, cno, usualscore, finalscore)
VALUES(student_id, course_id, usual_score, final_score);
END $$
DELIMITER ;
DELIMITER $$
CREATE PROCEDURE pro_out(IN student_id VARCHAR(10), IN course_id VARCHAR(10), IN usual_score INT, IN final_score INT)
BEGIN
CALL pro_insert(student_id, course_id, usual_score, final_score);
SELECT * FROM score WHERE sno = student_id AND cno = course_id;
END $$
DELIMITER ;
```
17. 查看p_student存储过程的定义:
```mysql
SHOW CREATE PROCEDURE p_student;
```
DELIMITER $$ CREATE PROCEDURE `stm`.`get_student_num`(OUT count_num CHAR(10)) BEGIN SELECT COUNT(sno) INTO count_num FROM student; END$$ DELIMITER ; CALL get_student_num(@count_num) SELECT @count_num
好的,根据您的要求,我已经创建了一个名为 `get_student_num` 的存储过程,代码如下:
```mysql
DELIMITER $$
CREATE PROCEDURE `get_student_num`(OUT count_num CHAR(10))
BEGIN
SELECT COUNT(sno) INTO count_num FROM student;
END;
$$
DELIMITER ;
```
该存储过程接受一个输出参数 count_num,用于返回学生人数信息,具体实现是通过查询 student 表获取记录数,并将结果存入 count_num 中。
接下来,您可以使用以下 SQL 语句调用该存储过程:
```mysql
CALL get_student_num(@count_num);
SELECT @count_num;
```
其中,@count_num 是一个用户变量,用于接收存储过程的输出参数。第一行代码调用了存储过程,并将结果存入 @count_num 变量中。第二行代码则直接查询 @count_num 变量的值,以显示学生人数信息。
阅读全文