各位用户为了找寻关于MYSQL存储过程即常用逻辑知识点总结的资料费劲了很多周折。这里教程网为您整理了关于MYSQL存储过程即常用逻辑知识点总结的相关资料,仅供查阅,以下为您介绍关于MYSQL存储过程即常用逻辑知识点总结的详细内容
Mysql存储过程
1.创建存储过程语法(格式)
? 1 2 3 4 5DELIMITER $
CREATE
PROCEDURE
存储过程名A(
IN
传入参数名a
INT
,
IN
传入参数名b
VARCHAR
(20),
OUT
返回参数名c
INT
)
BEGIN
内容..........
END
$
解析:
IN 代表传入的参数,定义传入参数名,并且后面跟上传入参数类型(INT,VARCHAR,DOUBLE,........) OUT 代表存储过程执行完返回的数据,定义参数名,并且后面跟上参数类型(INT,VARCHAR,DOUBLE,........) INOUT 代表既可以传入也可以返回 ,定义参数名,并且后面跟上参数类型(INT,VARCHAR,DOUBLE,........)2.存储过程内具体语法与逻辑
A.定义变量语法:
? 1DECLARE
变量名a 参数类型(
INT
,
VARCHAR
(20),BOOLEAN,........) [
DEFAULT
NULL
];
注:可以在参数类型后面加 DEFAULT NULL; 来设置初始值。
B.变量赋值:
方式1(直接对变量进行赋值):
? 1SET
定义的变量a = NEW();
方式2(sql查询的结果直接赋值给变量):
? 1SELECT `student`.age INTO 定义的变量a FROM `student` WHERE...........
方式3(sql查询的结果直接赋值给多个变量):
? 1SELECT
`student`.
name
AS
定义的变量a,`student`.age
AS
定义的变量b
INTO
定义的变量a,定义的变量b
FROM
`student` ...............
c.逻辑判断:
? 1 2 3 4 5 6 7 8 9 10 11 12 13#IF判断:
IF 条件语句(3>5)
THEN
条件为
TRUE
时执行.........;
END
IF;
#IF
ELSE
判断:
IF 条件(a>0)
THEN
条件为(a>0)时执行........;
ELSE
IF 条件(a<0)
THEN
条件为(a<0)时执行.......;
ELSE
其它执行.......;
END
IF;
D.游标,(LOOP)循环:
? 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22#例.单游标循环:
create
procedure
my_procedure()
-- 创建存储过程
begin
-- 开始存储过程
declare
my_id
varchar
(32);
-- 自定义变量1
declare
my_name
varchar
(50);
-- 自定义变量2
DECLARE
done
INT
DEFAULT
FALSE
;
-- 自定义控制游标循环变量,默认false
DECLARE
cur
CURSOR
FOR
(
SELECT
id,
name
FROM
t_people );
-- 定义游标并输入结果集
DECLARE
CONTINUE
HANDLER
FOR
NOT
FOUND
SET
done =
TRUE
;
-- 绑定控制变量到游标,游标循环结束自动转true
OPEN
cur;
-- 打开游标
posLoop: LOOP
-- 开始循环体,myLoop为自定义循环名,结束循环时用到
FETCH
cur
into
my_id, my_name;
-- 将游标当前读取行的数据顺序赋予自定义变量12
IF done
THEN
-- 判断是否继续循环
LEAVE posLoop;
-- 结束循环
END
IF;
-- 自己要做的事情,在 sql 中直接使用自定义变量即可
UPDATE
t_user
SET
c_name = my_name
WHERE
id = my_id
and
rtrim(ltrim(c_name)) =
''
;
-- 左右去空格
COMMIT
;
-- 提交事务
END
LOOP posLoop;
-- 结束自定义循环体
CLOSE
cur;
-- 关闭游标
END
;
-- 结束存储过程
?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
#例.多游标循环:
create
procedure
my_procedure()
-- 创建存储过程begin -- 开始存储过程
declare
my_id
varchar
(32);
-- 自定义变量1
declare
my_name
varchar
(50);
-- 自定义变量2
DECLARE
done
INT
DEFAULT
FALSE
;
-- 自定义控制游标循环变量,默认false
DECLARE
cur_1
CURSOR
FOR
(
SELECT
id,
name
FROM
t_people );
-- 定义游标并输入结果集
DECLARE
cur_2
CURSOR
FOR
(
SELECT
id_2,name_2
FROM
t_people_2);
--定义游标并输入结果集
DECLARE
CONTINUE
HANDLER
FOR
NOT
FOUND
SET
done =
TRUE
;
-- 绑定控制变量到游标,游标循环结束自动转true
OPEN
cur_1;
-- 打开游标
posLoop: LOOP
-- 开始循环体,myLoop为自定义循环名,结束循环时用到
FETCH
cur_1
into
my_id, my_name;
-- 将游标当前读取行的数据顺序赋予自定义变量12
IF done
THEN
-- 判断是否继续循环
LEAVE posLoop;
-- 结束循环
END
IF;
-- 自己要做的事情,在 sql 中直接使用自定义变量即可
UPDATE
..........;
--自己要做的具体操作
END
LOOP posLoop;
-- 结束自定义循环体
CLOSE
cur_1;
-- 关闭游标
SET
done =
FALSE
;
-- 因为当第一个游标遍历完后其值被handler设置为TRUE了,如果不用set把它设置为 FALSE ,那么第二个游标就不会遍历了。(最好是在每个打开游标的操作前都用该语句,以确保游标能真正遍历)
OPEN
cur_2;
-- 打开游标
posLoop_2: LOOP
-- 开始循环体,myLoop为自定义循环名,结束循环时用到
FETCH
cur_2
into
my_id, my_name;
-- 将游标当前读取行的数据顺序赋予自定义变量12
IF done
THEN
-- 判断是否继续循环
LEAVE posLoop_2;
-- 结束循环
END
IF;
-- 自己要做的事情,在 sql 中直接使用自定义变量即可
INSERT
..........;
--自己要做的具体操作
END
LOOP posLoop_2;
-- 结束自定义循环体
CLOSE
cur_2;
-- 关闭游标
END
;
-- 结束存储过程
3.存储过程的调用
? 1 2 3 4 5 6#调用没有返回值的存储过程CALL 存储过程名(参数.....);
#调用有返回值的存储过程(获得返回值)
CALL 存储过程名(@aaa);
SELECT
@aaa;
4.删除存储过程
? 1DROP
PROCEDURE
存储过程名;
5.注意事项
存储过程中的分号(;)很重要,尽量不要省略。
原文链接:https://www.cnblogs.com/Moming0/p/11428960.html