欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

MYSQL存储过程即常用逻辑知识点总结

程序员文章站 2022-07-07 11:32:04
mysql存储过程 1.创建存储过程语法(格式) delimiter $ create procedure 存储过程名a(in 传入参数名a int,in...

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.注意事项

存储过程中的分号(;)很重要,尽量不要省略。