首页 数据库 mysql教程 MySQL触发器的创建与删除_MySQL

MySQL触发器的创建与删除_MySQL

Jun 01, 2016 pm 01:34 PM
文章 触发器

bitsCN.com

MySQL触发器的创建与删除

 

下面的文章主要描述的是MySQL触发器的正确创建步骤,MySQL触发器的删除,你如果对MySQL触发器的正确创建步骤,MySQL触发器的删除有兴趣的话你就可以点击以下的文章进行观看了。

 

1、创建MySQL触发器:

 

语法:

 

CREATE TRIGGER trigger_name trigger_time trigger_event ON tbl_name   

FOR EACH ROW   

BEGIN   

trigger_stmt   

END;   

CREATE TRIGGER trigger_name trigger_time trigger_event ON tbl_name  

FOR EACH ROW   

BEGIN  

trigger_stmt  

END;  

 

例子

 

CREATE TRIGGER SetUserHome after insert ON users   

FOR EACH ROW   

BEGIN   

update `users` set homeLocationX = 128,  

homeLocationY=128, homeLocationZ=30   

where uuid = NEW.uuid  

END  

 

以上的例子是错误的, 让本表进行触发时进行更新会让程序进入死循环。

 

系统会报这样的错误:it is already used by statement which invoked this stored function/trigger.

 

应该改成以下语句:

 

CREATE TRIGGER SetUserHome before insert ON users   

FOR EACH ROW   

BEGIN   

set New.homeLocationX = 128;  

set New.homeLocationY = 128;  

set New.homeLocationZ=30;   

END  

 

大写的为关键字

 

trigger_name:触发器的名字,我常用的命名规则t_name_tableName_(b|a)(i|u|d),t:MySQL触发器标识,name:英文名,tableName:表名,b(BEFORE):标识是触发事件之前,a(AFTER):标识触发事件之后,i(insert):标识insert事件,u(update):标识update事件,d(delete):标识delete事件;

 

trigger_time:触发时间(BEFORE或AFTER)

 

trigger_event:事件名(insert或update或delete)

 

tbl_name:表名(必须是永久性表)

 

trigger_stmt:执行语句(可以是复合语名),使用别名OLD和NEW,能够引用与触发程序相关的表中的列。

 

2、删除解发器

 

语法:

 

DROP TRIGGER [schema_name.]trigger_name;  

 

注意:以上操作均需SUPER权限

 

示例:

 

DROP TRIGGER t_wiley_hotelComment_bu;   

delimiter //   

CREATE TRIGGER t_wiley_hotelComment_bu BEFORE UPDATE ON hotel_comment   

FOR EACH ROW   

BEGIN   

IF OLD.ispass=0 && NEW.ispass=1 THEN   

UPDATE hotel_info SET sumcommentsumcomment=sumcomment+1,

 

 

sumconsumesumconsume=sumconsume+NEW.consume,sumservicesumservice=sumservice+NEW.service, 

 

 

sumroomsumroom=sumroom+NEW.room,sumentironsumentiron=sumentiron+NEW.entironment,

 

 

totaltotal=total+(NEW.service+NEW.room+NEW.entironment) WHERE hotel_id=NEW.hotel_id;   

ELSEIF OLD.ispass=1 && NEW.ispass=0 THEN   

UPDATE hotel_info SET sumcommentsumcomment=sumcomment-1,

 

 

sumconsumesumconsume=sumconsume-NEW.consume,sumservicesumservice=sumservice-NEW.service, 

 

 

sumroomsumroom=sumroom-NEW.room,sumentironsumentiron=sumentiron-NEW.entironment,

 

 

totaltotal=total-(NEW.service+NEW.room+NEW.entironment) WHERE hotel_id=NEW.hotel_id;   

END IF;   

END;//   

delimiter ;  

 

以上的相关内容就是对MySQL触发器的使用的介绍,望你能有所收获。

bitsCN.com
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

Video Face Swap

Video Face Swap

使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热门文章

<🎜>:泡泡胶模拟器无穷大 - 如何获取和使用皇家钥匙
3 周前 By 尊渡假赌尊渡假赌尊渡假赌
北端:融合系统,解释
3 周前 By 尊渡假赌尊渡假赌尊渡假赌

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

热门话题

Java教程
1664
14
CakePHP 教程
1423
52
Laravel 教程
1320
25
PHP教程
1269
29
C# 教程
1249
24
今日头条发布文章怎么才能有收益?今日头条发布文章获得更多收益方法! 今日头条发布文章怎么才能有收益?今日头条发布文章获得更多收益方法! Mar 15, 2024 pm 04:13 PM

一、今日头条发布文章怎么才能有收益?今日头条发布文章获得更多收益方法!1.开通基础权益:原创文章选择投放广告可获得收益,视频必须要原创横屏才会有收益。2.开通百粉权益:粉丝量达到百粉以上,微头条、原创问答创作及问答均可获得收益。3.坚持原创作品:原创作品包含文章、微头条及问题等,要求300字以上。注意违规抄袭作品作为原创发布,会被扣信用分,即使有收益也会被扣除。4.垂直度:做专业领域一类的文章,不能随意跨领域写文章,会得不到合适的推荐,达不到作品的专和精,难以吸引粉丝读者。5.活跃度:活跃度高,

如何隐藏文本直到在 Powerpoint 中单击 如何隐藏文本直到在 Powerpoint 中单击 Apr 14, 2023 pm 04:40 PM

如何在 PowerPoint 中的任何点击之前隐藏文本如果您希望在单击 PowerPoint 幻灯片上的任意位置时显示文本,那么设置起来既快速又容易。要在 PowerPoint 中单击任何按钮之前隐藏文本:打开您的 PowerPoint 文档,然后单击“插入 ”菜单。单击新幻灯片。选择空白或其他预设之一。仍然在插入菜单中,单击文本框。在幻灯片上拖出一个文本框。单击文本框并输入您

如何在MySQL中使用PHP编写触发器 如何在MySQL中使用PHP编写触发器 Sep 21, 2023 am 08:16 AM

如何在MySQL中使用PHP编写触发器MySQL是一种常用的关系型数据库管理系统,而PHP是一种流行的服务器端脚本语言。在MySQL中使用PHP编写触发器可以帮助我们实现自动化的数据库操作。本文将介绍如何使用PHP来编写MySQL触发器,并提供具体的代码示例。在开始之前,确保已经安装了MySQL和PHP,并且已经建立了相应的数据库表。一、创建PHP文件和数据

如何在MySQL中使用PHP编写自定义触发器和存储过程 如何在MySQL中使用PHP编写自定义触发器和存储过程 Sep 20, 2023 am 11:25 AM

如何在MySQL中使用PHP编写自定义触发器和存储过程引言:在开发应用程序时,我们经常需要在数据库层面进行一些操作,如插入、更新或删除数据。MySQL是一个广泛使用的关系型数据库管理系统,而PHP是一种流行的服务器端脚本语言。本文将介绍如何在MySQL中使用PHP编写自定义触发器和存储过程,并提供具体的代码示例。一、什么是触发器和存储过程触发器(Trigg

oracle如何添加触发器 oracle如何添加触发器 Dec 12, 2023 am 10:17 AM

在Oracle数据库中,您可以使用CREATE TRIGGER语句来添加触发器。触发器是一种数据库对象,它可以在数据库表上定义一个或多个事件,并在事件发生时自动执行相应的操作。

如何在MySQL中使用Python编写自定义触发器 如何在MySQL中使用Python编写自定义触发器 Sep 20, 2023 am 11:04 AM

如何在MySQL中使用Python编写自定义触发器触发器是MySQL中的一种强大的功能,它可以在数据库中的表上定义一些自动执行的操作。而Python则是一种简洁而强大的编程语言,能够方便地与MySQL进行交互。本文将介绍如何使用Python编写自定义触发器,并提供具体的代码示例。首先,我们需要安装并导入PyMySQL库,它是Python与MySQL数据库进行

MySQL触发器中参数的使用方法 MySQL触发器中参数的使用方法 Mar 16, 2024 am 09:27 AM

MySQL触发器是一种在数据库管理系统中用于监控特定表的操作,并根据预定义的条件执行相应操作的特殊程序。在创建MySQL触发器时,我们可以使用参数来灵活地传递数据和信息,让触发器更具通用性和适用性。在MySQL中,触发器可以在特定表的INSERT、UPDATE、DELETE操作前或者后触发执行相应的逻辑。使用参数可以使得触发器更具灵活性,可以根据需要传递需要

mysql的触发器是什么级的 mysql的触发器是什么级的 Mar 30, 2023 pm 08:05 PM

mysql的触发器是行级的。按照SQL标准,触发器可以分为两种:1、行级触发器,对于修改的每一行数据都会激活一次,如果一个语句插入了100行数据,将会调用触发器100次;2、语句级触发器,针对每个语句激活一次,一个插入100行数据的语句只会调用一次触发器。而MySQL中只支持行级触发器,不支持预语句级触发器。

See all articles