Maison> base de données> tutoriel mysql> le corps du texte

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

帅杰杰
Libérer: 2020-05-01 14:44:59
original
102 Les gens l'ont consulté

什么是存储过程?

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

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

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

存储过程的优点:

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

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

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

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

存储过程的缺点:

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

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

存储过程的创建和调用

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

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

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

创建存储过程

create procedure getStudentCount() begin select count(*) as num from student where classid=8; end
Copier après la connexion

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

1、查询

查询所有存储过程状态

show procedure status;
Copier après la connexion

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

show procedure status where db="数据库名";
Copier après la connexion

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

show procedure status where name like "%Student%";
Copier après la connexion

查询存储过程详细代码

show create procedure 过程名;
Copier après la connexion

2、修改

alter procedure 过程名([过程参数[,…]])过程体;
Copier après la connexion

3、删除

drop procedure 过程名;
Copier après la connexion

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

调用存储过程

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

call 存储过程名([过程参数[,...]])
Copier après la connexion

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Étiquettes associées:
1
source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal
À propos de nous Clause de non-responsabilité Sitemap
Site Web PHP chinois:Formation PHP en ligne sur le bien-être public,Aidez les apprenants PHP à grandir rapidement!