什么是存储过程?
存储过程(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 存储过程名([过程参数[,...]])
Atas ialah kandungan terperinci 【MySql教程】轻松带你了解存储过程及使用方式. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!