当前位置:家常菜>百科>科技>正文

mysql存储过程实例详解

人气:313 ℃/2024-08-15 09:54:26

mysql存储过程是怎样的呢?下面就让我们一起来了解一下吧:

mysql中存储过程是属于一种在数据库中存储复杂程序,以便于外部程序调用的一种数据库对象。

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

mysql存储过程优点:

1、存储过程可以进行封装,并且隐藏复杂的商业逻辑。

2、存储过程能够回传值,并能接受参数。

3、存储过程通常是无法使用SELECT指令来进行运行的,由于它是属于子程序,与查看表、数据表或是用户定义函数不同。

4、存储过程能够用于数据检验,强制实行商业逻辑等。

当然,它也存在了一部分缺点:

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

2、存储过程的性能调校与撰写,一般会受限于各种数据库系统。

参考示例:

存储过程的操作,具体代码如下:

创建:

CREATE PROCEDURE sp_name([proc_parameter[,...]])

    [characteristic...] routine_body

    

proc_parameter:

[IN|OUT|INOUT] param_name type    #type: Any valid MySQL data type

characteristic:

LANGUAGE SQL

|[NOT] DETERMINISTIC|{CONTAINS SQL|NO SQL|READS SQL DATA|MODIFIES SQL DATA}|SQL SECURITY {DEFINAER|INVOKER}|COMMENT 'string'

routine_body:

Valid SQL procedure statement or statements

修改:

ALTER PROCEDURE sp_name [characteristic...]

characteristic:

{CONTAINS SQL|NO SQL|READS SQL DATA|MODIFIES SQL DATA}|SQL SECURITY {DEFINAER|INVOKER}|COMMENT 'string'

调用:

CALL sp_name([parameter[,...]])

删除:

DROP PROCEDURE sp_name

查看:

show PROCEDURE STATUS [like 'pattern']

SHOW CREATE PROCEDURE sp_name

在MYSQL 存储过程中的关键语法:

声明语句结束符,可自定义为:

DELIMITER $$

DELIMITER //

声明存储过程,即:

CREATE PROCEDURE demo_in_parameter(IN p_in int)       

存储过程开始与结束符号,即:

BEGIN .... END    

变量赋值,即:

SET @p_in=1  

变量定义:

DECLARE l_int int unsigned default 4000000; 

创建mysql存储过程、存储函数:

create procedure 存储过程名(参数)

存储过程体:

create function 存储函数名(参数)

示例:

若是删除给定球员参加的所有比赛,具体代码为:

mysql> delimiter $$#将语句的结束符号从分号;临时改为两个$$(可以为自定义)

mysql> CREATE PROCEDURE delete_matches(IN p_playerno INTEGER)

    -> BEGIN

    -> DELETE FROM MATCHES

    ->    WHERE playerno = p_playerno;

    -> END$$

Query OK, 0 rows affected (0.01 sec)

mysql> delimiter;#将语句的结束符号恢复为分号

  • 八月最后一天发朋友圈文案(八月朋友圈文案可爱)

    1、八月,再见。九月,你好!希望九月有惊喜和收获等着我。2、八月再见九月你好,好好工作、美味开启,享受每一天的生活,精致从早餐开始,用选择和努力去惊艳时光,而非用抱怨和等待去荒...

    说说查看全文>>
  • 宝来后视镜外壳如何拆

    宝来后视镜外壳拆除的方法:先用一字改锥从镜壳和反光镜底座的边缘撬起,撬开一条缝隙,取出一字改锥,将一字改锥伸进镜片与镜壳的缝隙中,然后同样取出一字改锥,将一字改锥伸到右面的镜片...

    问答查看全文>>
  • 宝马x1u盘使用教程是什么?

    宝马x1u盘使用教程是:首先在电脑上下载音乐到U盘,然后把U盘插到播放器的USB接口,打开就可以了。2019款宝马X1外观上,前脸采取双肾式进气格栅设计,下进气口采用梯形设计,...

    问答查看全文>>
  • c1可以升b1驾照多少钱?

    c1可以升b1驾照根据地区不同,一般为5000-10000之间,它的规定:1、有C1驾照需要三年后才可以增加B1,增加B1要求为持原驾照准驾车型资格三年以上,并在申请前最近连续...

    问答查看全文>>
  • 二手奔驰e级测评怎么样?

    二手奔驰e级测评:1、据悉,下一代E级将采用MRA纵置后驱模块化平台,刚在2014北美车展首发的新一代C级W205也出自MRA平台。从新一代C级上便可知,采用新平台后整车质量得...

    问答查看全文>>
本网站部分内容、图文来自于网络,如有内容侵犯您的合法权益,请及时与我们联系,我们将第一时间安排核实及删除!
CopyRight © 2007-2024 家常菜 All Rights Reserved. 手机版