笔记-8:mysql触发器
1.触发器介绍
- 触发器是一个被指定关联到一个表的数据库对象,当对一个表的特定事件出现时,将会被激活。
- mysqk触发器只支持:INSERT、UPDATE、DELETE语句。
- 每个表每个事件每次只允许一个触发器,因此,每个表最多支持6个触发器。
2.创建触发器
create
TRIGGER trigger_name trigger_time trigger_event
ON tb_name FOR EACH ROW trigger_body # trigger_name:触发器名称。
# trigger_time:触发器被触发的时该。即使用DEFORE、AFTER用于表示触发器是在激活它的语句之前或者之后触发。如果希望验证新数据是否满足使用的限制,则使用BEFORE;如果希望在激活触发器的语句执行之后完成几个或更多的改变,通过使用AFTER。
# trigger_event:触发事件,用于指定激活触发器的语句的种类。(INSERT、UPDATE、DELETE)。
# tb_name:与触发器相关联的表名。
# FOR EACH ROW:指定对于受触发事件影响的每一行都要激活触发器的动作。
# trigger_body:触发器动作主体,包含触发器激活时将要执行的mysql语句。
# 在表tb_student中创建一个触发器tb_student_insert_trigger,用于每次向表tb_student中插入一行数据时将学生变量str的值设置为”on student added!“
create trigger tb_student_insert_trigger after insert on tb_student FOR EACH ROW SET @ str='on student added!'; insert into tb_student values('','张晓勇','男','1997-12-11','山西','汉','AC1301'); select @ str; # 验证触发器
3.查看触发器
SHOW TRIGGERS [{FROM | IN} db_name]
4.删除触发器
DROP TRIGGER [IF EXISTS] trigger_name
删除tb_student表的触发器tb_student_insert_trigger
drop trigger if exists tb_student_trigger;
- 当删除表时,会自动删除该表相关联的触发器。
- 触发器不能更新与覆盖,如果需要修改触发器,必须先删除,然后再创建。
5.使用触发器
5.1 INSERT触发器
insert触发器可以在insert语句执行之前或之后执行。需要注意的点:
- 在insert触发器代码内可引用一个NEW的虚拟表来访问被插入的行。
- 在before insert触发器中,NEW中的值也可以被更新,即允许更改被插入的值。
- 在AUTO_INCREMENT列,NEW在insert执行之前是0,在insert执行之后将。
# 在表tb_student中重新创建触发器tb_student_insert_trigger,用于每次向表tb_student中插入一行数据时将学生变量str的值设置为新插入学生的学号。
create trigger tb_student_insert_trigger AFTER INSERT on tb_student FOR EACH ROW SET @ str=NEW.studentNo;
5.2 DELETE触发器
DELETE触发器可以在DELETE语句执行之前或之后执行。需要注意的点:
- 在DELETE触发器代码内可以引用一个名为OLD的虚拟表来访问被删除的行。
- OLD中的值全部是只读,不能被更新。
5.3 UPDATE触发器
UPDATE触发器在UPDATE语句执行之前或之后执行。需要注意的点:
- 在UPDATE触发器代码内可以引用一个名为OLD的虚拟表访问以前的值,也可以引用一个名为NEW的虚拟表访问新更新的值。
- 在BEFORE UPDATE触发器中,NEW中的值可能也被更新,即允许更改将要用于UPDATE语句中的值。
- OLD中的值全部是只读的,不能被更新。
- 当触发器涉及对表自身的更新操作时,只能使用BEFORE UPDATE触发器,不能使用AFTER UPDATE触发器。
# 在表tb_student中创建一个触发器tb_student_update_trigger,用于每次更新tb_student时将该表中nation列的值设置为native列的值。
create trigger tb_student_update_trigger BEFORE UPDATE ON tb_student FOR EACH ROW SET NEW.nation=OLD.native; update tb_student SET nation='壮' where studentName='张晓勇';
笔记-8:mysql触发器的更多相关文章
- MySQL笔记 存储过程 游标 触发器
第二十三章 使用存储过程 MySQL5 中添加了存储过程的支持. 大多数SQL语句都是针对一个或多个表的单条语句.并非所有的操作都怎么简单.经常会有一个完整的操作需要多条才能完成 存储过程简单来说,就 ...
- MYSQL进阶学习笔记七:MySQL触发器的创建,应用及管理!(视频序号:进阶_16,17)
知识点八:MySQL触发器的应用(16,17) 触发器的定义: 什么是触发器: 触发器是一种特殊的存储过程,它在插入,删除或修改特定表中的数据是触发执行,他比数据库本身标准的功能有更精细和更复杂的数据 ...
- 【笔记】MySQL的基础学习(二)
[笔记]MySQL的基础学习(二) MySQL 老男孩 一 视图 视图其实就是给表起个别名 1.创建视图 格式:CREATE VIEW 视图名称 AS SQL语句 CREATE VIEW v1 AS ...
- MySQL触发器如何正确使用
MySQL触发器如何正确使用 2010-05-18 15:58 佚名 博客园 字号:T | T 我们今天主要向大家介绍的是MySQL触发器进行正确使用,其中包括对MySQL触发器发器的语句创建,触发时 ...
- 【转】mysql触发器的实战(触发器执行失败,sql会回滚吗)
1 引言Mysql的触发器和存储过程一样,都是嵌入到mysql的一段程序.触发器是mysql5新增的功能,目前线上凤巢系统.北斗系统以及哥伦布系统使用的数据库均是mysql5.0.45版本,很多程 ...
- mysql笔记04 MySQL高级特性
MySQL高级特性 1. 分区表:分区表是一种粗粒度的.简易的索引策略,适用于大数据量的过滤场景.最适合的场景是,在没有合适的索引时,对几个分区进行全表扫描,或者是只有一个分区和索引是热点,而且这个分 ...
- redis作为mysql的缓存服务器(读写分离,通过mysql触发器实现数据同步)
一.redis简介Redis是一个key-value存储系统.和Memcached类似,为了保证效率,数据都是缓存在内存中.区别的是redis会周期性的把更新的数据写入磁盘或者把修改操作写入追加的记录 ...
- mysql触发器的例子--插入前更新数据
本文介绍下,一个mysql触发器的例子,在数据插入前更新相关内容,有需要的朋友参考下. mysql触发器的例子,如下: view source print? 001 mysql> CREATE ...
- mysql触发器的作用及语法
触发器是一种特殊的存储过程,它在插入,删除或改动特定表中的数据时触发运行,它比数据库本身标准的功能有更精细和更复杂的数据控制能力. 数据库触发器有下面的作用: 1.安全性.能够基于数据库的值使用户具有 ...
- MySQL 触发器结构及三个案例demo
--你必须拥有相当大的权限才能创建触发器(CREATE TRIGGER),如果你已经是Root用户,那么就足够了.这跟SQL的标准有所不同. CREATE TRIGGER语法 CREATE TRIGG ...
随机推荐
- mysql解压文件安装
mysql.zip版本的安装教程 MySQL zip版本安装 一直以来都习惯了使用MySQL安装文件(.exe),今天下载了一个.zip版本的MySQL,安装过程中遇到了一些问题,如下: 1.在M ...
- Java 实例 - instanceof 关键字用法
Java 实例 - instanceof 关键字用法 instanceof 是 Java 的一个二元操作符,类似于 ==,>,< 等操作符. instanceof 是 Java 的保留关键 ...
- flutter doctor出现问题 [!] Android toolchain - develop for Android devices (Android SDK version 28.0.3) X Android license status unknown. Try re-installing or updating your Android SDK Manager. 的解决方案
首先,问题描述: flutter doctor Doctor summary (to see all details, run flutter doctor -v): [√] Flutter (Cha ...
- 项目管理工具-OmniPlan 3 for Mac
链接:https://pan.baidu.com/s/1tp_37fHXHwJuklL1nNSwig 密码:l0sf 激活迷药(里面自带的keygen不能用,用这个好使): Name: Appked ...
- angular 中的[ngClass]、[ngStyle]
<div style="text-align:center"> <h1> Welcome to {{ title }}! </h1> </ ...
- UI——DOM
原文链接:Introduction to the DOM Introduction The Document Object Model, usually referred to as the DOM, ...
- linux下使用SVN上传项目
linux下使用SVN上传项目 摘自:https://blog.csdn.net/puppet_/article/details/78259591 2017年10月17日 13:51:33 puppe ...
- [Paper翻译]Scalable Lock-Free Dynamic Memory Allocation
原文: http://citeseerx.ist.psu.edu/viewdoc/download?doi=10.1.1.87.3870&rep=rep1&type=pdf Abstr ...
- springboot配置虚拟路径访问用户上传的附件及图片资源
在springmvc项目中,我们通常把图片及附件存放到WEB-INF/upload类似的路径. springboot项目是通过jar包方式运行的. 笔者曾尝试以下代码,把图片转成base64格式的图片 ...
- LeetCode_172. Factorial Trailing Zeroes
172. Factorial Trailing Zeroes Easy Given an integer n, return the number of trailing zeroes in n!. ...