饿虎岗资源网 Design By www.oxmxm.com
本文实例讲述了mysql存储过程原理与用法。分享给大家供大家参考,具体如下:
本文内容:
- 什么是存储过程
- 存储过程的创建
- 存储过程的使用
- 查看存储过程
- 修改存储过程
- 删除存储过程
首发日期:2018-04-17
什么是存储过程:
- 存储过程存储了一系列sql语句
- 存储过程的需求场景:下边是一个经典的需求场景,很多Mysql的书都有:
- 存储过程存储了一系列sql语句,使得简化了操作,不要求重复执行一系列操作。只需要在需要的时候调用一下存储过程就行了。
- 一般来说,可以认为存储过程的功能与函数的功能类似(应该都学过函数吧),但只是要注意存储过程没有返回值,所以可以依据函数可用场景来理解存储过程。
补充:
- 存储过程与触发器的区别:触发器触发事件就执行一系列语句;而存储过程是调用,而且存储过程还要根据情况考虑执行“另外一系列语句”。
- 存储过程与函数的区别:函数有返回值,而存储过程没有【所以不能使用在select语句中】
存储过程的创建:
- create procedure 存储过程名 ([参数列表]) begin sql 语句 end;
- 参数列表的格式:[类型限定 变量名 数据类型]
- 参数列表有自己的类型限定,这个类型限定与数据类型不同,它是限定参数的作用范围
- in:限定这个参数是传值给存储过程,既然是传值,所以可以是变量或常量数据【in修饰的参数一般是传入存储过程中作为某些条件的,不会被存储过程修改】
- out:限定这个参数是存储过程传出的一个值,因为有值的返回,所以这个参数必须是一个变量【存储过程中会给out修饰的变量赋值,使得过程外部可以获取这个更改的值】
- inout:inout是上面两者的叠加,既可以被存储过程内部使用,又可以修改后被外部使用,因为有值的返回,所以这个参数必须是一个变量
- 参数列表有自己的类型限定,这个类型限定与数据类型不同,它是限定参数的作用范围
- 参数列表的格式:[类型限定 变量名 数据类型]
- 理论上,对于希望简洁代码的地方都可以使用存储过程来处理,比如希望快速使用多条select,又比如希望从数据中取出多个值赋值给变量;所以下面只给出用法,应用场景就不讲述了。
- 1:不传入参数,只执行某些特定代码
- 2.传入参数,并利用参数作为条件执行代码
- 3.传入参数,并利用参数作为条件执行代码,同时利用变量获取结果。
- 【下面的call是调用过程】
-- 最简单的例子 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等选项,有兴趣可以自行百度。这里不讲解,仅一提有此知识点。
- comment:是这个存储过程的一个描述
存储过程的使用:
- 调用存储过程:call 存储过程名();
- 带参数的调用存储过程:call 存储过程名(参数);
-
- 对于in类型的,参数可以是数值,可以是变量
- 对于out\inout类型的,参数必须是变量
- 所有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;【显示的内容包括创建时间、注释、定义的用户、安全类型等等】
修改存储过程:
删除存储过程:
- 语法:drop procedure 存储过程名;
- 示例:
-
drop procedure getInfo;
更多关于MySQL相关内容感兴趣的读者可查看本站专题:《MySQL存储过程技巧大全》、《MySQL常用函数大汇总》、《MySQL日志操作技巧大全》、《MySQL事务操作技巧汇总》及《MySQL数据库锁相关技巧汇总》
希望本文所述对大家MySQL数据库计有所帮助。
饿虎岗资源网 Design By www.oxmxm.com
广告合作:本站广告合作请联系QQ:858582 申请时备注:广告合作(否则不回)
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
饿虎岗资源网 Design By www.oxmxm.com
暂无评论...
更新日志
2024年09月20日
2024年09月20日
- 【小提琴】陈立新《思乡曲》2004[FLAC+CUE]
- 《战地》新作明年初大规模测试!EA已内部测试一年
- 《GTAOL》PC版时隔多年更新反作弊!小助手宣布跑路
- EA称AI是其业务核心!能提高开发效率、节约成本
- 卫华.1990-太阳升【BMG】【WAV+CUE】
- 呼吸乐队.1992-THEBREATHING【深飞】【WAV+CUE】
- 李玟.2008-1994-2008豪华典藏精选2CD【SONY】【WAV+CUE】
- 《张学友 再现歌神的光辉岁月 梦想成真 2CD》[WAV/分轨][1.2GB]
- 《海来阿木 高音测试王》[WAV+CUE][500MB]
- 《许巍 歌声给你生命的力量 珍藏许巍 3CD》[WAV/分轨][2GB]
- 《直到黎明重制版》配置要求推荐
- 《赛博朋克2077》2.13版本更新内容一览
- 《神话时代:重述版》评测:粉丝们的朝花夕拾
- 战锤40K星际战士2先锋职业介绍|先锋职业技能效果一览
- 战锤40K星际战士2重装职业介绍|重装职业技能效果一览