触发器
--触发器:在增删改之前或之后,触发执行触发器中定义的sql语句集合,可用于保持数据完整性,日志记录,数据校验等操作,
触发器类型有new:插入或更新后的新数据,old:删改之前的数据
创建触发器:
create trigger trigger_name
before/after insert/delete/UPDATE
on table_name
[for each row] --行级触发器,mysql只有行级触发器,Oracle还有语句级触发器
begin
trigger_statement;
end;
--通过触发器记录test表的数据变更日志,包含增删改
--受限创建一张日志表
create table test_log(
id int(11) not null auto_increment,
operation varchar(20) not null comment '操作类型,insert/delete/update',
operate_time datetime not null comment '操作时间',
operate_id int(11) not null comment '操作表的id',
operate_params varchar(500) comment '操作参数',
primary key(id)
)ENGINE=innodb DEFAULT charset=utf8;
--创建插入型触发器
create trigger test_insert_trigger
after insert
on test
for each row
begin
insert into test_log(id,operation,operate_time,operate_id,operate_params)values(null,'insert',now(),new.id,concat('id:',new.id,',name:',new.name));
end$
向test表中插入一条数据 insert into test value(null,'trigger')
查看日志表是否有触发器向里面插入数据select * from test_log
--创建更新型触发器
create trigger test_update_trigger
after update
on test
for each row
begin
insert into test_log(id,operation,operate_time,operate_id,operate_params)values(null,'update',now(),new.id,concat('更新之前:','id:',old.id,',name:',old.name,'更新之后,id:',new.id,',name:',new.name));
end$
查看触发器:
show triggers
删除触发器:
drop trigger trigger_name
原文地址:https://www.cnblogs.com/1--2/p/15020818.html
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- SpringBoot学习二:基础配置
- Spring Boot 学习三:静态资源、整合 Thymeleaf 页面模板、@RestControllerAdvice
- SpringBoot学习四:日志框架、SpringBoot自动化配置
- SpringBoot学习五:错误处理、跨域支持
- Spring Security安全
- SpringBoot定时任务
- MySQL优化以及索引的使用
- 前端表单提交String类型数据后端转日期数据
- Java - CentOS下JDK的安装与配置
- yum安装与配置 Tomcat
- org.apache.ibatis.ognl.OgnlException: source is null for getProperty(null, “xxxx“)] with root cause
- UnsatisfiedDependencyException
- Java8 Collectors.toMap的key重复
- bean无法注入(与文件包位置有关)及修改包项目、model名
- Jackson第一篇