SQL深入探究存储的过程
作者:黑码哥
存储过程是事先经经过编译并存储在数据库中的一段SQL语句的集合,调用存储过程可以简化应用开发人员的很多工作,减少数据在数据库和应用服务器之间的传输,对于高效数据处理的效率是有好处的
现需要向学生表中插入新的学生数据。但在插入学生数据的时,需要同
时检查老师表里的数据。如果插入学生的老师不在老师表里,则先向老师表中插入一条老师数据,再向学生表中插入学生数据。
步骤:
使用SELECT语句查询新学生的老师是否存在于老师表中;
- 如果不存在 ,则继续执行第2步;
- 如果存在,则直接跳到第3步;
向老师表中插入老师数据;向学生表中插入学生数据
上方需求我们可以通过存储过程实现
存储过程简介
现需要向学生表中插入新的学生数据。但在插入学生数据的时,需要同
时检查老师表里的数据。如果插入学生的老师不在老师表里,则先向老师表中插入一条老师数据,再向学生表中插入学生数据
存储过程:一组为了完成特定功能的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;
存储过程的优缺点
优点:
- 功能强大、灵活性高;
- 模块化,封装,代码复用;
缺点:
- 开发调试困难;
- 可移植性差,不同数据库,语法差别很大,移植困难;
到此这篇关于SQL深入探究存储的过程的文章就介绍到这了,更多相关SQL存储过程内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!