MySQL存储过程 (即函数)
SQL的Stored Procedure
存储过程,指的其实就是一个函数
。
既然是函数,那么就会涉及这几个要点:定义函数、使用函数、变量、参数、返回值等。
在MySQL中,这几个要点的语法如下:
- 定义函数:
CREATE PROCEDURE 函数名(参数列表) BEGIN ...具体的SQL语句... END
- 使用函数:
CALL 函数名(参数列表);
参数类型:
IN
: 参数被拷贝为函数内局部变量,不影响原本的变量值。func(IN age INT)...
OUT
: 参数只是传了个引用,函数内修改的话外部变量也会变。INOUT
: 函数内修改的话外部变量也会变。
- 声明变量:
DECLARE 变量名 类型 DEFAULT 默认值;
- 设置变量:
SET @变量名="Jason"
- 使用变量:调用时用
@变量名
,print显示时用SELECT @变量名;
函数定义即调用
单行函数:
CREATE PROCEDURE 函数名(参数) 一句SQL语句; -- 如: CREATE PROCEDURE GreetWorld(@whom) SELECT CONCAT('Hello', @whom);
多行函数:
-- DELIMITER // -- 分隔符 CREATE PROCEDURE 函数名(参数类型 参数名 数据类型) BEGIN 具体的SQL语句 具体的SQL语句 END // DELIMITER ; -- 分隔符 -- 示例: DELIMITER // CREATE PROCEDURE funcName(IN p_in int) BEGIN SELECT p_in; SET p_in=2; SELECT p_in; END // DELIMITER ;
调用函数:
-- 变量赋值 SET @p_in=1; -- 调用函数 CALL funcName(@p_in);
函数(存储过程)的其它操作:
-- 修改函数 ALTER PROCEDURE ..... -- 删除函数 DROPPROCEDURE 函数名 ;
变量操作
-- 声明一个函数内的新变量(必须放在函数最上方) DECLARE 变量名 数据类型 DEFAULT 默认值; -- 设置变量值 SET @x = 'Goodbye Cruel World'; -- 或 SELECT 'Hello World' into @x;
条件控制 IF-ELSE / CASE
IF-ELSE结构:
IF param=0 THEN update t set s1=s1+ ELSE update t set s1=s1+ END IF ;
CASE结构:
CASE var WHEN 0 THEN insert into t values(17); WHEN 1 THEN insert into t values(18); ELSE insert into t values(19); END CASE ;
循环语句 WHILE / REPEAT / LOOP / ITERATE
WHILE-DO方式
WHILE var < 100 DO 具体的SQL语句。 ENDWHILE ;
REPEAT方式:
REPEAT 具体SQL语句。 UNTIL var <= 100 ENDREPEAT ;
LOOP方式:
label: LOOP 具体SQL语句。 LEAVE label ; END LOOP
其中,采用循环标签标签名:
的方式可以加在While / Repeat / Loop前,这样就可以使用leave
语句退出循环,相当于break的意思。
ITERATE迭代方式:
label: LOOP IF var = 3 THEN ITERATE label ; END IF ; IF var >= 5 THEN LEAVE label ; END iF ; END LOOP ;
MySQL常用内置函数
相关推荐
hungzz 2020-06-16
muzirigel 2020-06-14
xiaobaif 2020-06-13
cyyking 2020-05-17
Omega 2020-08-16
zjyzz 2020-08-16
minggehenhao 2020-07-28
zhaojp0 2020-06-27
zjuwangleicn 2020-06-25
wenjieyatou 2020-06-17
liaomingwu 2020-06-16
gsmfan 2020-06-14
ncomoon 2020-06-14
Rain 2020-06-12
hanshangzhi 2020-06-12
talkingDB 2020-06-12
IBMRational 2020-06-09