mysql存储过程原理与用法详解
本文实例讲述了mysql存储过程原理与用法。分享给大家供大家参考,具体如下:
本文内容: 什么是存储过程 存储过程的创建 存储过程的使用 查看存储过程 修改存储过程 删除存储过程首发日期:2018-04-17
什么是存储过程: 存储过程存储了一系列sql语句 存储过程的需求场景:下边是一个经典的需求场景,很多Mysql的书都有:
-- 最简单的例子create procedure myselect()begin select @@version;end;create procedure getInfo(in mname varchar(15))begin select mname;end;call myselect();call getInfo('lilie');-- 能通过传参来获取指定内容的create procedure getInfo2(in mname varchar(15))begin select * from student where name =mname;end;call getInfo2('lilei');-- 将结果赋值给一个变量传到外部create procedure getInfo3(in mname varchar(15),out oname varchar(15))begin select name from student where name =mname into oname;end;call getInfo3('lilei',@mname);select @mname;补充: 与触发器类似,如果在命令行模式下进行存储过程创建,需要修改命令结束符。 还可以有一些特别的选项,特别的选项写在([参数列表]) 之后,begin之前comment:是这个存储过程的一个描述
create procedure myselect2()comment '我的一系列sql语句'begin select * from student; select * from class;end;show create procedure myselect2; 还有一些比如sql security等选项,有兴趣可以自行百度。这里不讲解,仅一提有此知识点。 存储过程的使用: 调用存储过程:call 存储过程名(); 带参数的调用存储过程:call 存储过程名(参数);对于in类型的,参数可以是数值,可以是变量 对于outinout类型的,参数必须是变量 所有MySQL变量都必须以 @ 开始 示例:call myselect('lilei',@变量名);示例:call myselect(@变量名,@变量名)
下面调用的存储过程就是上面创建存储过程中定义的存储过程:
call myselect();call getInfo('lilie');set @mname='lilei';call getInfo(@mname);call getInfo3('lilei',@mname);变量的使用: out和inout能修改会被存储过程修改的变量,但这个修改会在存储过程调用结束后才会成功修改【就好像如果在过程内部现有一条命令是修改的,可以在此命令后面查看一下变量,发现全局变量并没有改变,改变的只是局部变量】。 所有MySQL变量都必须以 @ 开始 存储过程中,使用局部变量可以使用select 变量名;使用全局变量可以使用select @变量名; 关于具体变量的定义与使用将在我的另外一篇博文中讲解。超链接:mysql之变量查看存储过程: 查看存储过程的创建语句:show create procedure 存储过程名; 查看存储过程状态:show procedure status;【显示的内容包括创建时间、注释、定义的用户、安全类型等等】修改存储过程: 修改存储过程只能修改那些选项(这里不讲解那些具体选项,想了解的可以自行百度),并不能修改传入传出参数或者sql语句。 alter procedure 存储过程名 选项; 删除存储过程: 语法:drop procedure 存储过程名; 示例:
drop procedure getInfo;
更多关于MySQL相关内容感兴趣的读者可查看本站专题:《MySQL存储过程技巧大全》、《MySQL常用函数大汇总》、《MySQL日志操作技巧大全》、《MySQL事务操作技巧汇总》及《MySQL数据库锁相关技巧汇总》
希望本文所述对大家MySQL数据库计有所帮助。
相关文章: