富贵资源网 Design By www.hznty.com
Mysql存储过程
1.创建存储过程语法(格式)
DELIMITER $ 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.定义变量语法:
DECLARE 变量名a 参数类型(INT,VARCHAR(20),BOOLEAN,........) [DEFAULT NULL];
注:可以在参数类型后面加 DEFAULT NULL; 来设置初始值。
B.变量赋值:
方式1(直接对变量进行赋值):
SET 定义的变量a = NEW();
方式2(sql查询的结果直接赋值给变量):
SELECT `student`.age INTO 定义的变量a FROM `student` WHERE...........
方式3(sql查询的结果直接赋值给多个变量):
SELECT `student`.name AS 定义的变量a,`student`.age AS 定义的变量b INTO 定义的变量a,定义的变量b FROM `student` ...............
c.逻辑判断:
#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)循环:
#例.单游标循环: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; -- 结束存储过程
#例.多游标循环: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.存储过程的调用
#调用没有返回值的存储过程CALL 存储过程名(参数.....); #调用有返回值的存储过程(获得返回值) CALL 存储过程名(@aaa); SELECT @aaa;
4.删除存储过程
DROP PROCEDURE 存储过程名;
5.注意事项
存储过程中的分号(;)很重要,尽量不要省略。
富贵资源网 Design By www.hznty.com
广告合作:本站广告合作请联系QQ:858582 申请时备注:广告合作(否则不回)
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
富贵资源网 Design By www.hznty.com
暂无评论...
P70系列延期,华为新旗舰将在下月发布
3月20日消息,近期博主@数码闲聊站 透露,原定三月份发布的华为新旗舰P70系列延期发布,预计4月份上市。
而博主@定焦数码 爆料,华为的P70系列在定位上已经超过了Mate60,成为了重要的旗舰系列之一。它肩负着重返影像领域顶尖的使命。那么这次P70会带来哪些令人惊艳的创新呢?
根据目前爆料的消息来看,华为P70系列将推出三个版本,其中P70和P70 Pro采用了三角形的摄像头模组设计,而P70 Art则采用了与上一代P60 Art相似的不规则形状设计。这样的外观是否好看见仁见智,但辨识度绝对拉满。