mysql存储过程 触发器(数据库中存储过程和触发器有什么区别)

精选笔记 bchgfjyf56547 2024-04-17 14:49 11 0

一、五、MYSQL存储过程和函数

• create procedure用来创建存储过程,create function用来创建函数

• Delimiter命令是改变语句的结束符,MySQL默认的结束符为;号,由于procedure和function中的;号并不代表创建的结束,所以要替换成另外的结束符以便表示创建的结束

• rontine_body子句可以包含一个简单的SQL语句,也可以包含多个SQL语句,通过begin…end将这多个SQL语句包含在一起

• MySQL存储过程和函数中也可以包含类似create和drop等DDL语句

• comment子句用来写入对存储过程和函数的注释

• Language子句用来表示此存储过程和函数的创建语言

•存储过程和函数被标注为deterministic表明当输入相同的参数是会返回相同的结果,反之如果是not deterministic则表示相同参数不会是相同结果,默认是not deterministic

•相关属性短语只有咨询含义,并不是强制性的约束

• Drop procedure/function语句用来删除指定名称的存储过程或函数

• Begin…end语句通常出现在存储过程、函数和触发器中,其中可以包含一个或多个语句,每个语句用;号隔开

•标签label可以加在begin…end语句以及loop, repeat和while语句

•语句中通过iterate和leave来控制流程,iterate表示返回指定标签位置,leave表示跳出标签

• Declare语句通常用来声明本地变量、游标、条件或者handler

• Declare语句只允许出现在begin… end语句中而且必须出现在第一行

• Declare的顺序也有要求,通常是先声明本地变量,再是游标,然后是条件和handler

•本地变量可以通过declare语句进行声明

•声明后的变量可以通过select… into var_list进行赋值,或者通过set语句赋值,或者通过定义游标并使用fetch… into var_list赋值

•通过declare声明变量方法:

• MySQL支持if,case,iterate,leave,loop,while,repeat语句作为存储过程和函数中的流程控制语句,另外return语句也是函数中的特定流程控制语句

• Case语句在存储过程或函数中表明了复杂的条件选择语句

• IF语句在存储过程或函数中表明了基础的条件选择语句

其中在 function里面,只有 DETERMINISTIC, NO SQL和 READS SQL DATA被支持。如果我们开启了 bin-log,我们就必须为我们的 function指定一个参数。

在 MySQL中创建函数时出现这种错误的解决方法:

set global log_bin_trust_function_creators=TRUE;

• Iterate语句仅出现在loop,repeat,while循环语句中,其含义表示重新开始此循环

• Leave语句表明退出指定标签的流程控制语句块

•通常会用在begin…end,以及loop,repeat,while的循环语句中

• Loop语句是存储过程或函数中表达循环执行的一种方式

• repeat语句是存储过程或函数中表达循环执行的一种方式

• while语句是存储过程或函数中表达循环执行的一种方式

• Return语句用在函数中,用来终结函数的执行并将指定值返回给调用者

• Cursor游标用来声明一个数据集

•游标的声明必须在变量和条件声明之后,在handler声明之前

• Cursor close语句用来关闭之前打开的游标

• Cursor declare语句用来声明一个游标和指定游标对应的数据集合,通常数据集合是一个select语句

• Cursor fetch语句用来获取游标指定数据集的下一行数据并将各个字段值赋予后面的变量

• Open cursor语句用来打开一个之前已经声明好的游标

• Declare condition语句命名特定的错误条件,而该特定错误可以在declare…handler中指定处理方法

•比如在MySQL中1051error code表示的是unknown table的错误,如果要对这

个错误做特殊处理,可以用三种方法:

• Declare handler语句用来声明一个handler来处理一个或多个特殊条件,当其中的某个条件满足时则触发其中的statement语句执行

• Statement可以是一个简单SQL语句,也可以是begin…end组成的多个语句

• Handler_action子句声明当执行完statement语句之后应该怎么办

Condition_value的值有以下几种:

•当condition发生但没有声明handler时,则存储过程和函数依照如下规则处理

• create trigger语句用来创建一个触发器,触发器的作用是当表上有对应SQL语句发生时,则触发执行

•触发器创建时需要指定对应的表名 tbl_name

• Definer关键词用来指定trigger的安全环境

• Trigger_time指定触发器的执行时间,BEFORE和AFTER指定触发器在表中的每行数据修改前或者后执行

• Trigger_event指定触发该触发器的具体事件

• INSERT当新的一行数据插入表中时触发,比如通过执行insert,load data,replace语句插入新数据

• UPDATE当表的一行数据被修改时触发,比如执行update语句时

• DELETE当表的一行数据被删除时触发,比如执行delete,replace语句时

•当执行insert into… on duplicate key update语句时,当碰到重复行执行update时,则触发update下的触发器

•从5.7.2版本开始,可以创建具有相同trigger_time和trigger_event的同一个表上的多个触发器,默认情况下按照创建的时间依次执行,通过指定FOLLOWS/PRECEDES改变执行顺序,即FOLLOWS时表示新创建的触发器后执行,PRECEDES则表示新触发器先执行

• Trigger_body表示触发器触发之后要执行的一个或多个语句,在内部可以引用涉及表的字段, OLD.col_name表示行数据被修改或删除之前的字段数据,NEW.col_name表示行数据被插入或修改之后的字段数据

• Drop trigger语句用来删除一个触发器

• If exists短语用来避免删除不存在的触发器时引发报错

•当你执行drop table时,表上的触发器也被drop掉了

二、数据库中存储过程和触发器有什么区别

存储过程和触发器的区别有:存储过程可以采用输入参数而触发器不可以;存储过程可以返回零或n值而触发器无法返回值,存储过程中可以使用事务,而触发器不允许

【推荐课程:MySQL教程】

存储过程和触发器都是数据库中非常重要的知识,接下来将在文章中通过许多方面来比较这两者之间的不同,具有一定的参考作用希望对大家有所帮助。

什么是触发器?

触发器是数据库中的表/视图发生某些特定事件时自动执行的过程(代码段)。触发器主要用于维护数据库中的完整性。触发器还用于实施业务规则,审核数据库中的更改以及复制数据。最常见的触发器是在操作数据时触发数据操作语言(DML)触发器。某些数据库系统支持非数据触发器,这些触发器在发生数据定义语言(DDL)事件时触发。这些触发器可以特别用于审计。Oracle数据库系统支持模式级触发器

什么是存储过程?

存储过程是可以由访问关系数据库的应用程序。通常,存储过程用作验证数据和控制对数据库的访问。如果某些数据处理操作需要执行多个SQL语句,则此类操作将作为存储过程实现。调用存储过程时,必须使用CALL或EXECUTE语句。存储过程可以返回结果(例如SELECT语句的结果)。这些结果可以由其他存储过程或应用程序使用。用于编写存储过程的语言通常支持控制结构,例如if,while,for等。根据所使用的数据库系统,可以使用多种语言来实现存储过程

存储过程和触发器的区别

(1)存储过程是一组已创建并存储在数据库中的SQL语句。所以我们可以一遍又一遍地重用代码。而触发器是一种特殊的不是由用户直接调用存储过程,创建触发器时,会定义在针对特定表或列进行特定类型的数据修改时触发。

(2)用户可以使用Execute或Exec语句来直接调用或执行存储过程,而无法直接调用或执行触发器。触发相关事件时,只会自动执行触发器。

(3)存储过程可以采用输入参数,而触发器中不能将参数作为输入我们不能将参数作为输入传递给触发器。

(4)存储过程可以返回零或n值,触发器无法返回值。

(5)我们可以在存储过程中使用事务,触发器内不允许进行事务处理

(6)存储过程通常用于执行用户指定的任务,触发器通常用于审计工作

三、mysql触发器(MySQL触发器(定义、使用及示例))

MySQL触发器是一种特殊的存储过程,它是由MySQL服务器自动执行的一种数据库对象。当指定的事件发生时,触发器会被激活并执行相应的操作。这些事件可以是INSERT、UPDATE或DELETE语句的执行,也可以是表的创建或删除。MySQL触发器可以用于实现数据的自动更新、数据的验证和数据的审计等功能。

MySQL触发器的定义

MySQL触发器的定义包含以下几个部分:

1.触发器的名称:用于标识触发器的名称。

2.触发器的事件:触发器所要监控的事件,可以是INSERT、UPDATE或DELETE语句的执行,也可以是表的创建或删除。

3.触发器所在的表:触发器所要监控的表。

4.触发器的执行时间:触发器所要执行的时间,可以是BEFORE或AFTER。

5.触发器的执行语句:触发器所要执行的SQL语句。

MySQL触发器的使用

下面是一个MySQL触发器的示例:

```

CREATETRIGGER`trigger_name`BEFOREINSERTON`table_name`

FOREACHROWBEGIN

--触发器所要执行的SQL语句

END;

```

触发器的名称为`trigger_name`,它所要监控的事件是INSERT语句的执行,它所在的表为`table_name`,它所要执行的时间是BEFORE,它所要执行的SQL语句可以在BEGIN和END之间编写。

MySQL触发器的示例

下面是一个MySQL触发器的示例,该触发器在每次向`employee`表中插入新记录时,自动更新`department`表中的员工人数。

```

CREATETRIGGER`update_department_count`

AFTERINSERTON`employee`

FOREACHROWBEGIN

UPDATE`department`SET`count`=`count`+1WHERE`department_id`=NEW.`department_id`;

END;

```

该触发器的名称为`update_department_count`,它所要监控的事件是INSERT语句的执行,它所在的表为`employee`,它所要执行的时间是AFTER,它所要执行的SQL语句为UPDATE语句,它将`department`表中对应部门的员工人数加1。

MySQL触发器的注意事项

1.MySQL触发器只能在表级别上创建,不能在行级别上创建。

2.MySQL触发器可以使用NEW和OLD关键字来引用插入、更新或删除的行的值。

3.MySQL触发器可以使用IF和CASE语句来进行条件判断。

4.MySQL触发器可以使用RAISE_APPLICATION_ERROR函数来抛出异常。