亲宝软件园·资讯

展开

SQL深入探究存储的过程

黑码哥 人气:0

现需要向学生表中插入新的学生数据。但在插入学生数据的时,需要同

时检查老师表里的数据。如果插入学生的老师不在老师表里,则先向老师表中插入一条老师数据,再向学生表中插入学生数据。

步骤:

使用SELECT语句查询新学生的老师是否存在于老师表中;

向老师表中插入老师数据;向学生表中插入学生数据

上方需求我们可以通过存储过程实现

存储过程简介

现需要向学生表中插入新的学生数据。但在插入学生数据的时,需要同

时检查老师表里的数据。如果插入学生的老师不在老师表里,则先向老师表中插入一条老师数据,再向学生表中插入学生数据

存储过程:一组为了完成特定功能的SQL语句集,经编译后存储在数据库中,然后通过指定存储过程的名字并给定参数(如果该存储过程带有参数)来调用执行它。

存储过程的创建及调用

存储过程的创建:使用关键字CREATE PROCEDURE

存储过程的删除

如何删除存储过程

比如:现需要向学生表中插入新的学生数据。但在插入学生数据的时,需要同时检查老师表里的数据。如果插入学生的老师不在老师表里,则先向老师表中插入一条老师数据,再向学生表中插入学生数据。

CREATE PROCEDURE sp_add_student(
IN i_student_id VARCHAR(50), IN i_student_name VARCHAR(100),
IN i_gender VARCHAR(10), IN i_birth_day DATE,
IN i_age INT, IN i_class_id VARCHAR(50),
IN i_score DECIMAL(18,2), IN i_teacher_id VARCHAR(20)
)
BEGIN
IF NOT EXISTS(SELECT 1 FROM teacher WHERE teacher_id = 'i_teacher_id') THEN
INSERT INTO teacher(teacher_id) VALUES (i_teacher_id);
END IF;
INSERT INTO student VALUES(
i_student_id,i_student_name,i_gender,i_birth_day,
i_age, i_class_id, i_score, i_teacher_id
);
END;

存储过程的调用:使用关键字CALL

如:

CALL sp_add_student( 
'S20170091', '杨艳', '女', '2003-04-09',
15, 'G0206', 89.23, 'T0021' 
);

存储过程的删除:使用关键字DROP PROCEDURE

如:DROP PROCEDURE sp_add_student;

存储过程的优缺点

优点:

缺点:

加载全部内容

相关教程
猜你喜欢
用户评论