本文实例讲述了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数据库计有所帮助。
标签:
mysql,存储过程
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件!
如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
暂无“mysql存储过程原理与用法详解”评论...
《魔兽世界》大逃杀!60人新游玩模式《强袭风暴》3月21日上线
暴雪近日发布了《魔兽世界》10.2.6 更新内容,新游玩模式《强袭风暴》即将于3月21 日在亚服上线,届时玩家将前往阿拉希高地展开一场 60 人大逃杀对战。
艾泽拉斯的冒险者已经征服了艾泽拉斯的大地及遥远的彼岸。他们在对抗世界上最致命的敌人时展现出过人的手腕,并且成功阻止终结宇宙等级的威胁。当他们在为即将于《魔兽世界》资料片《地心之战》中来袭的萨拉塔斯势力做战斗准备时,他们还需要在熟悉的阿拉希高地面对一个全新的敌人──那就是彼此。在《巨龙崛起》10.2.6 更新的《强袭风暴》中,玩家将会进入一个全新的海盗主题大逃杀式限时活动,其中包含极高的风险和史诗级的奖励。
《强袭风暴》不是普通的战场,作为一个独立于主游戏之外的活动,玩家可以用大逃杀的风格来体验《魔兽世界》,不分职业、不分装备(除了你在赛局中捡到的),光是技巧和战略的强弱之分就能决定出谁才是能坚持到最后的赢家。本次活动将会开放单人和双人模式,玩家在加入海盗主题的预赛大厅区域前,可以从强袭风暴角色画面新增好友。游玩游戏将可以累计名望轨迹,《巨龙崛起》和《魔兽世界:巫妖王之怒 经典版》的玩家都可以获得奖励。
更新动态
2024年11月24日
2024年11月24日
- 凤飞飞《我们的主题曲》飞跃制作[正版原抓WAV+CUE]
- 刘嘉亮《亮情歌2》[WAV+CUE][1G]
- 红馆40·谭咏麟《歌者恋歌浓情30年演唱会》3CD[低速原抓WAV+CUE][1.8G]
- 刘纬武《睡眠宝宝竖琴童谣 吉卜力工作室 白噪音安抚》[320K/MP3][193.25MB]
- 【轻音乐】曼托凡尼乐团《精选辑》2CD.1998[FLAC+CUE整轨]
- 邝美云《心中有爱》1989年香港DMIJP版1MTO东芝首版[WAV+CUE]
- 群星《情叹-发烧女声DSD》天籁女声发烧碟[WAV+CUE]
- 刘纬武《睡眠宝宝竖琴童谣 吉卜力工作室 白噪音安抚》[FLAC/分轨][748.03MB]
- 理想混蛋《Origin Sessions》[320K/MP3][37.47MB]
- 公馆青少年《我其实一点都不酷》[320K/MP3][78.78MB]
- 群星《情叹-发烧男声DSD》最值得珍藏的完美男声[WAV+CUE]
- 群星《国韵飘香·贵妃醉酒HQCD黑胶王》2CD[WAV]
- 卫兰《DAUGHTER》【低速原抓WAV+CUE】
- 公馆青少年《我其实一点都不酷》[FLAC/分轨][398.22MB]
- ZWEI《迟暮的花 (Explicit)》[320K/MP3][57.16MB]