什么是存储过程?

存储过程(Stored Procedure)是一种在数据库中存储复杂程序,以便外部程序调用的一种数据库对象。

存储过程是为了完成特定功能的SQL语句集,经编译创建并保存在数据库中,用户可以通过指定存储过程的名字并给定参数(需要时)来调用。

存储过程思想上很简单,就是数据库SQL语言层面的代码封装重用。

存储过程的优点:

存储过程可封装,并隐藏复杂的商业逻辑。

存储过程可以回传值,并可以接受参数。

存储过程无法使用select指令来运行,因为它是子程序,与查看表,数据表或用户定义函数不同。

存储过程可以用在数据检验,强制实行商业逻辑等。

存储过程的缺点:

存储过程,往往定制化于特定的数据库上,因为支持的编程语言不同。当切换到其他厂商的数据库系统时,需要重写原有的存储过程。

存储过程的性能调校和撰写,受限于各种数据库系统。

存储过程的创建和调用

存储过程就是具有名字的一段代码,用来完成一个特定的功能。

创建存储过程保存在数据库的数据字典中。

create procedure 存储过程名称(in|out|inout 参数名称 参数类型,……)
begin
过程体;
end

创建存储过程

create procedure getStudentCount()
begin
select count(*) as num from student where classid=8;
end

存储过程的查询、修改、删除

1、查询

查询所有存储过程状态

show procedure status;

查看对应数据库下所有存储过程状态

show procedure status where db="数据库名";

查看名称包含Student的存储过程状态

show procedure status where name like "%Student%";

查询存储过程详细代码

show create procedure 过程名;

2、修改

alter procedure 过程名([过程参数[,…]])过程体;

3、删除

drop procedure 过程名;

注:不能在一个存储过程中删除另一个存储过程,只能调用另一个存储过程。

调用存储过程

mysql存储过程用call和过程名以及一个括号,括号里面根据需要,加入参数,参数包括输入参数、输出参数、输入输出参数调用。

call 存储过程名([过程参数[,...]])