mysql存储过程原理与用法详解
作者:随风行云 发布时间:2024-01-26 02:50:54
本文实例讲述了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等选项,有兴趣可以自行百度。这里不讲解,仅一提有此知识点。
存储过程的使用:
调用存储过程: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;【显示的内容包括创建时间、注释、定义的用户、安全类型等等】
修改存储过程:
修改存储过程只能修改那些选项(这里不讲解那些具体选项,想了解的可以自行百度),并不能修改传入传出参数或者sql语句。
alter procedure 存储过程名 选项;
删除存储过程:
语法:drop procedure 存储过程名;
示例:
drop procedure getInfo;
希望本文所述对大家MySQL数据库计有所帮助。
来源:https://www.cnblogs.com/progor/p/8866574.html


猜你喜欢
- 1、replicate_do_db 和 replicate_ignore_db 不要同时出现。容易出现混淆。也是毫无意义的。 Replica
- 本文介绍FCKeditor在Java环境下的使用方法。一、简介 功能:所见即所得,支持图片和Flash,工具栏可自由配置,使用简单兼容性:I
- 本文实例讲述了python实现比较两段文本不同之处的方法。分享给大家供大家参考。具体实现方法如下:# find the difference
- 因为固体物理书上的球面投影图太难看,就自学 javascipt 用 echarts 做了个可交互的,效果如下:上面为立方晶系主要晶面(晶向)
- 一、变量声明的方式let / constlet / const 共同点1.都是块级作用域2.在同一个作用域下,变量名不允许重复3.他们声明的
- 本文实例讲述了Python mutiprocessing多线程池pool操作。分享给大家供大家参考,具体如下:python — mutipr
- 图片的宽度和高度是未知的,没有一个固定的尺寸,在这个前提下要使图片在一个固定了宽度和高度的容器中垂直居中,想想感觉还是挺麻烦的,由于最近的项
- 一. 认证系统概要create_user 创建用户authenticate 验证登录login 记住用户的登录状态logout 退出登录is
- 该语言中缩进是其精髓,通过缩进可以表示函数、循环等程序结构的范围。有时写完程序后,发现所有程序需要放入函数def中,这时就需要对一整块程序同
- 1、基本概念K近邻法(K-nearest neighbors,KNN)既可以分类,也可以回归。KNN做回归和分类的区别在于最后预测时的决策方
- 前言大家都知道,英文的分词由于单词间是以空格进行分隔的,所以分词要相对的容易些,而中文就不同了,中文中一个句子的分隔就是以字为单位的了,而所
- import导入模块import time #导入的时模块中的所有内容print(time.ctime()) #调用模块中的函数
- 看过数据库的备份与还原。大多数都是用组件来完成的。其实可通过sql语句来完成。 由于时间关系,未对参数进行验证和界面美化。代码
- 一、什么是shutilshutil可以简单地理解为sh + util ,shell工具的意思。shutil模块是对os模块的补充,主要针对文
- 机房一台服务器上的mysql运行一段时间了,突然出现了一个很奇怪的现象:重启后无法恢复了!准确情况是:启动mysql后随即就又关闭了。查看m
- 下面就是JavaScript实现大文件上传功能的代码bigFileUpload.jsconst path = require('pa
- 偶然看到 Tanel Poder 提到的一个 Metalink Note (438452.1): Performance Tools Qui
- 在我们关于SQL服务器安全系列的这文章里,我们的目标是向你提供安全安装SQL服务器所需要的工具和信心,这样的话,你有价值的数据就会受到保护,
- 本文实例为大家分享了Python实现五子棋游戏的具体代码,供大家参考,具体内容如下class CheckerBoard(): &
- 前言去年在做golangserver的时候,内部比较头疼的就是在线服务发布的时候,大量用户的请求在发布时候会被重连,在那时候也想了n多的方法