Rumah > pangkalan data > tutorial mysql > 【MySql教程】轻松带你了解存储过程及使用方式

【MySql教程】轻松带你了解存储过程及使用方式

帅杰杰
Lepaskan: 2020-05-01 14:44:59
asal
239 orang telah melayarinya

什么是存储过程?

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

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

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

存储过程的优点:

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

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

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

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

存储过程的缺点:

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

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

存储过程的创建和调用

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

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

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

创建存储过程

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

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

1、查询

查询所有存储过程状态

show procedure status;
Salin selepas log masuk

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

show procedure status where db="数据库名";
Salin selepas log masuk

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

show procedure status where name like "%Student%";
Salin selepas log masuk

查询存储过程详细代码

show create procedure 过程名;
Salin selepas log masuk

2、修改

alter procedure 过程名([过程参数[,…]])过程体;
Salin selepas log masuk

3、删除

drop procedure 过程名;
Salin selepas log masuk

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

调用存储过程

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

call 存储过程名([过程参数[,...]])
Salin selepas log masuk

Atas ialah kandungan terperinci 【MySql教程】轻松带你了解存储过程及使用方式. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Label berkaitan:
1
sumber:php.cn
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan