mysql_存储过程

语法:create procedure 存储过程名称([ 参数列表 ]) begin --sql语句 end ;

在命令行中,执行创建存储过程的sql时,需要通过关键字delimiter指定sql语句的结束符。

如用!作为结束符:

 

调用: call 名称 ([ 参数 ]) ;

 

查看: 查询指定数据库的存储过程及状态信息: select * from information_schema.routines where routines_schema = 'xxx' ;

            查寻某个存储过程的定义: show create procedure 存储过程名称 ;

 

删除: drop procedure  [ if exists ] 存储过程名称 ;

 

一、变量

1、系统变量:是MySQL服务器提供,不是用户定义的,属于服务器层面,分为全局变量(GLOBAL)、会话变量(SESSION)。

 

查看系统变量:查看所有系统变量: show [ session | global ] variables ;

                         可以通过like模糊匹配方式直接查找变量:  show [ session | global ] variables like ' ...... ' ;

                         查看指定变量的值: select @@[ session | global ] 系统变量名 ;

 

设置系统变量:set [ session | global ] 系统变量名 = 值 ;  (session是会话级别,不影响其他会话)

                         set @@[ session | global ]系统变量名 = 值 ;

注意:如果没有指定session/global,默认是session,会话变量。

           mysql服务器重新启动之后,所设置的全局参数会失效,要想不失效,可以在/etc/my.cnf中配置。

 

 

2、用户定义变量:是用户根据需要自己定义的变量,用户变量不用提前声明,再用的时候直接用 "@变量名" 使用就可以。其作用域为当前连接。

   赋值:set @var_name = expr [ , @var_name = epr ] ...... ;

             set @var_name := expr [ , @var_name = epr ] ...... ;

             select @var_name := expr [ , @var_name = epr ] ...... ;

             select 字段名 into @var_name from 表名 ;

   使用:select @var_name ;

注意:用户定义的变量无需对其进行声明或初始化,只不过获取到的值为NULL。

 

 

3、局部变量:是根据需要定义的在局部生效的变量,访问之前,需要declare声明,可用作存储过程内的局部变量和参数,局部变量的范围是在其内声明的begin...end块。

   声明: declare 变量名 变量类型 [ default ...... ] ;

变量类型就是数据库字段类型: int、bigint、char、varchar、date、time等。

   赋值:set 变量名 = 值 ;

              set 变量名 := 值 ;

              select 字段名 int 变量名 from 表名 ...... ;

 

 

二、if判断

语法: if  条件1 then

                    ......

            elseif 条件2 then          --可选

                    ......

            else                            --可选

                    ......

            else if ;

 

 

三、参数

in 该参数作为输入,也就是需要调用时传入值  。默认。

out 该参数作为输出,也就是该参数可以作为返回值。

inout 既可以作为输入参数,也可以作为输出参数。

用法: 存储过程名称([ in/out/inout 参数名 参数类型 ])

 

 

四、游标cursor

用来存储查询结果集的数据类型,在存储过程和函数中可以使用游标对结果集进行循环的处理。游标的使用包括游标的声明、open、fetch、close。

声明游标:declare 游标名称 cursor for 查询语句;

 

打开游标:open 游标名称 ;

 

获取游标记录: fetch 游标名称 into 变量 [ , 变量 ] ;

 

关闭游标:close 游标名称 ;

 

posted @ 2022-07-15 09:50  小王同学学编程  阅读(128)  评论(0编辑  收藏  举报
levels of contents