MYSQL存储过程即常用逻辑知识点总结
Mysql存储过程
1.创建存储过程语法(格式)
DELIMITER$ CREATEPROCEDURE存储过程名A(IN传入参数名aINT,IN传入参数名bVARCHAR(20),OUT返回参数名cINT) BEGIN 内容.......... END$
解析:
- IN代表传入的参数,定义传入参数名,并且后面跟上传入参数类型(INT,VARCHAR,DOUBLE,........)
- OUT代表存储过程执行完返回的数据,定义参数名,并且后面跟上参数类型(INT,VARCHAR,DOUBLE,........)
- INOUT代表既可以传入也可以返回,定义参数名,并且后面跟上参数类型(INT,VARCHAR,DOUBLE,........)
2.存储过程内具体语法与逻辑
A.定义变量语法:
DECLARE变量名a参数类型(INT,VARCHAR(20),BOOLEAN,........)[DEFAULTNULL];
注:可以在参数类型后面加DEFAULTNULL;来设置初始值。
B.变量赋值:
方式1(直接对变量进行赋值):
SET定义的变量a=NEW();
方式2(sql查询的结果直接赋值给变量):
SELECT`student`.ageINTO定义的变量aFROM`student`WHERE...........
方式3(sql查询的结果直接赋值给多个变量):
SELECT`student`.nameAS定义的变量a,`student`.ageAS定义的变量bINTO定义的变量a,定义的变量bFROM`student`...............
c.逻辑判断:
#IF判断: IF条件语句(3>5)THEN 条件为TRUE时执行.........; ENDIF; #IFELSE判断: IF条件(a>0)THEN 条件为(a>0)时执行........; ELSEIF条件(a<0)THEN 条件为(a<0)时执行.......; ELSE 其它执行.......; ENDIF;
D.游标,(LOOP)循环:
#例.单游标循环:createproceduremy_procedure()--创建存储过程 begin--开始存储过程 declaremy_idvarchar(32);--自定义变量1 declaremy_namevarchar(50);--自定义变量2 DECLAREdoneINTDEFAULTFALSE;--自定义控制游标循环变量,默认false DECLAREcurCURSORFOR(SELECTid,nameFROMt_people);--定义游标并输入结果集 DECLARECONTINUEHANDLERFORNOTFOUNDSETdone=TRUE;--绑定控制变量到游标,游标循环结束自动转true OPENcur;--打开游标 posLoop:LOOP--开始循环体,myLoop为自定义循环名,结束循环时用到 FETCHcurintomy_id,my_name;--将游标当前读取行的数据顺序赋予自定义变量12 IFdoneTHEN--判断是否继续循环 LEAVEposLoop;--结束循环 ENDIF; --自己要做的事情,在sql中直接使用自定义变量即可 UPDATEt_userSETc_name=my_nameWHEREid=my_idandrtrim(ltrim(c_name))='';--左右去空格 COMMIT;--提交事务 ENDLOOPposLoop;--结束自定义循环体 CLOSEcur;--关闭游标 END;--结束存储过程
#例.多游标循环:createproceduremy_procedure()--创建存储过程begin--开始存储过程 declaremy_idvarchar(32);--自定义变量1 declaremy_namevarchar(50);--自定义变量2 DECLAREdoneINTDEFAULTFALSE;--自定义控制游标循环变量,默认false DECLAREcur_1CURSORFOR(SELECTid,nameFROMt_people);--定义游标并输入结果集 DECLAREcur_2CURSORFOR(SELECTid_2,name_2FROMt_people_2);--定义游标并输入结果集 DECLARECONTINUEHANDLERFORNOTFOUNDSETdone=TRUE;--绑定控制变量到游标,游标循环结束自动转true OPENcur_1;--打开游标 posLoop:LOOP--开始循环体,myLoop为自定义循环名,结束循环时用到 FETCHcur_1intomy_id,my_name;--将游标当前读取行的数据顺序赋予自定义变量12 IFdoneTHEN--判断是否继续循环 LEAVEposLoop;--结束循环 ENDIF; --自己要做的事情,在sql中直接使用自定义变量即可 UPDATE..........;--自己要做的具体操作 ENDLOOPposLoop;--结束自定义循环体 CLOSEcur_1;--关闭游标 SETdone=FALSE;--因为当第一个游标遍历完后其值被handler设置为TRUE了,如果不用set把它设置为FALSE,那么第二个游标就不会遍历了。(最好是在每个打开游标的操作前都用该语句,以确保游标能真正遍历) OPENcur_2;--打开游标 posLoop_2:LOOP--开始循环体,myLoop为自定义循环名,结束循环时用到 FETCHcur_2intomy_id,my_name;--将游标当前读取行的数据顺序赋予自定义变量12 IFdoneTHEN--判断是否继续循环 LEAVEposLoop_2;--结束循环 ENDIF; --自己要做的事情,在sql中直接使用自定义变量即可 INSERT..........;--自己要做的具体操作 ENDLOOPposLoop_2;--结束自定义循环体 CLOSEcur_2;--关闭游标 END;--结束存储过程
3.存储过程的调用
#调用没有返回值的存储过程CALL存储过程名(参数.....); #调用有返回值的存储过程(获得返回值) CALL存储过程名(@aaa); SELECT@aaa;
4.删除存储过程
DROPPROCEDURE存储过程名;
5.注意事项
存储过程中的分号(;)很重要,尽量不要省略。