mysql存储过程原理与用法详解存储过程原理与用法详解
本文实例讲述了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))
评论0