mysql创建乘积语法的触发器_创建Mysql触发器的语法介绍

news/2024/7/7 1:10:11 标签: 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;大写的为关键字

trigger_name:Mysql触发器的名字,我常用的命名规则t_name_tableName_(b|a)(i|u|d),t:触发器标识,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、删除Mysql解发器

语法:

DROP TRIGGER [schema_name.]trigger_name;

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

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触发器的使用的介绍,望你能有所收获。


http://www.niftyadmin.cn/n/1270268.html

相关文章

Android 单例模式的正确姿势

单例模式是使用得最多的设计模式,模版代码也很多。但是如果使用不当还是容易出问题。 DCL模式(双重检查锁定模式)的正确使用方式 一般我们使用DCL方法来实现单例模式时都是这样的模版代码: private static Singleton mSingleton null; private Singleto…

vscode 断点调试知乎_VSCode原理解析 断点调试

背景 今年年初,有幸参与了IDE 共建项目组, 打造阿里生态体系内的公共IDE底层,而作为一款面向开发者的IDE,调试能力的支持一定程度上决定着一款IDE的开发体验;VSCode作为微软体系下一款当前最热的IDE开发工具,在调试领域上的探索实践是很好的学习案例,有道是:借他山之石,…

jta mysql_Springboot + Atomikos + Druid + Mysql 实现JTA分布式事务

DataSource 配置1 packagecom.cheng.dynamic.config;23 importjava.util.Properties;45 importjavax.sql.DataSource;67 importorg.springframework.beans.factory.annotation.Autowired;8 importorg.springframework.boot.jta.atomikos.AtomikosDataSourceBean;9 importorg.sp…

linux mysql 查看死锁_MySQL 死锁的详细分析方法

用数据库的时候,偶尔会出现死锁,针对我们的业务系统,出现死锁的直接结果就是系统卡顿、客户找事儿,所以我们也在想尽全力的消除掉数据库的死锁。出现死锁的时候,如果只是想解锁,用show full processlist看下…

echarts的日常(教学篇)

1.开发流程2.案例 2.1 入门demo2.2 echarts的常用属性。 1 title (标题)2 lengend (切换组件图例)3 grid (网格)4 xAxis(x轴)5 yAxis(y轴)6 toolbox (工具包)7 tooltip (鼠标悬停提示…

mysql设置变量用来排序_MySQL关于使用变量实现各种排序的示例代码分析

这篇文章主要介绍了MySQL使用变量实现各种排序,需要的朋友可以参考下核心代码--下面我演示下MySQL中的排序列的实现--测试数据CREATE TABLE tb(score INT);INSERT tb SELECT5 UNION ALL SELECT4 UNION ALL SELECT4 UNION ALL SELECT4 UNION ALL SELECT3 UNION ALL SELECT2 UNIO…

步步深入MySQL:架构-查询执行流程-SQL解析顺序!

一、前言 本文将从MySQL总体架构--->查询执行流程--->语句执行顺序来探讨一下其中的知识。 二、MySQL架构总览 架构最好看图,再配上必要的说明文字。 下图根据参考书籍中一图为原本,再在其上添加上了自己的理解。从上图中我们可以看到,…

mysql为什么产生死锁_mysql死锁是怎么造成的

造成mysql死锁的原因:两个或两个以上的进程在执行过程中争夺资源。mysql中有三种锁,分别是表级锁、行级锁和页面锁。其中,表级锁开销小、加锁快,不会出现死锁情况。mysql是一种关系型数据库管理系统,使用的 SQL 语言是…