1.概述
存储程序可以封装一些语句,为用户提供一种简单的方式来调用这个存储程序,从而间接执行其封装的语句。
根据调用方式的不同,可把存储程序分为存储例程、触发器、事件几种类型。其中,存储例程又可被细分为存储函数和存储过程。
2.用户自定义变量
MYSQL中,可通过SET语句来自定义一些自己的变量。
如:SET @a = 1;
在我们的自定义变量前面必须加一个@符号。
在使用SET语句时,如变量名前没有加@符号,则MYSQL会把这个变量当作系统变量来对待。
之后想查看这个变量的值,使用SELECT @变量名;
如:SELECT @a;
同一个变量也可存储不同类型的值。如,再把一个字符串赋给变量a。
如:SET @a = ‘哈哈哈’;
除了把一个常量赋给一个变量,也可把一个变量赋给另一个变量。
如:SET @b = @a;
变量a,b是独立的。此后a改变不会影响b。
当某个查询的结果集是一行一列时,可将查询结果集赋给变量。
如:SET @a = (SELECT m1 FROM t1 LIMIT 1);
也可用INTO子句完成类似功能。
如:SELECT n1 FROM t1 LIMIT 1 INTO @b;
效果等价于SET @b = (SELECT n1 FROM t1 LIMIT 1);
当某个查询的结果集是一行多列。如想将结果集中各列赋值给不同的变量,不能用SET,只能用INTO。
如:SELECT m1, n1 FROM t1 LIMIT 1 INTO @a, @b;
3.存储函数
存储程序可以分为存储例程,触发器,事件几种类型。
存储例程需我们去手动调用,触发器和事件都是MySQL服务器在特定条件下自己调用的。
存储例程又可分为存储函数,存储过程。
3.1.创建存储函数
存储函数是一种函数,在函数定义中书写MySQL语句。