本文章的素材与知识来自李国良老师和王珊老师。
存储过程和函数
一.存储过程
1.语法
2.示例
(1)
使用DELIMITER更换终止符后用于编写存储过程语句后,在下次执行SQL语句时记得再使用DELIMITER将终止符再换回分号。
使用DELIMITER更换终止符后,存储过程中的BEGIN和END间的SQL语句仍然是使用分号作为终止符。
(2)
SELECT ... INTO x ;将查询结果存入变量x中。
二.函数
1.语法
函数的传参方向只能为IN,因此无需像存储过程一样指定。
函数必须指定返回值类型,因此一定要有RETURNS语句。
2.示例
示例中创建函数时缺少了BEGIN和END,得加上。
三.存储过程和函数的删除
四.区别与适用场景
1.区别
(1)参数方向
存储过程的参数方向可以为:IN、OUT、INOUT,因此需要指定参数方向。
函数的参数方向只能为:IN,因此无需指定参数方向。
(2)返回值类型声明
存储过程的返回值是通过OUT或INOUT参数返回的,因此无需通过RETURNS子句声明返回值类型。
函数的返回值是通过RETURN返回的,因此必须通过RETURNS子句声明返回值类型。
(3)返回值个数
存储过程可以通过多个OUT或INOUT参数返回多个值。
函数只能通过RETURN返回指定的某一类型的单值或表对象。
(4)调用
存储过程可以通过CALL语句作为一个独立的部分来执行和调用。
函数只能作为查询语句的一部分来调用,当作值或表来使用。
(5)对数据库的操作
存储过程可以执行更新表的数据库操作。
函数不能执行更新表的数据库操作。
2.适用场景
五.变量和流程控制
1.变量
(1)变量使用范围
(2)变量定义
(3)变量赋值
2.流程控制------IF
(1)语法
(2)示例
3.流程控制------LOOP
(1)语法
使用LOOP语句,最好加上LOOP标签,用于LEAVE后加上要退出的LOOP循环的标签。