mysql14. 创建存储过程 p_student,从student表中检索出所有电话以135开头的学生的学号、姓名、出生日期和电话等信息。 15. 创建存储过程pro_select(),用指定的学号和课程号为参数查询学生成绩,输出参数为学生平时成绩和结业成绩。 16. 创建一个存储过程 pro_insert(),向 score表中插入一行记录,然后创建另一存储过程pro_out(),调用存储过程pro_insert(),并查询输出score表中插入的记录。 17. 查看p_student存储过程的定义。
时间: 2024-02-03 10:11:59 浏览: 94
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;
```
阅读全文