Mysql中的触发器定义与使用
作者:菜到极致就是渣 时间:2024-01-26 10:37:45
一、触发器的介绍
触发器是与表有关的数据库对象,指在insert/update/delete 之前或之后,触发并执行
触发器中定义的SQL语句集合。触发器的这种特性可以协助应用在数据库端确保数据的
完整性,日志记录,数据校验等操作。
使用别名old和new来引用触发器中发生变化的记录内容,这与其它的数据库是相似的。
现在触发器还只支持行级触发,不支持语句级触发。
触发器类型 new和old
insert型触发器 new表示将要挥着已经新增的数据
update型触发器 old表示修改之前的数据,new表示将要或者已经修改后的数据
delete型触发器 old表示将要或者已经删除的数据
二、触发器的语法
语法:
1:创建触发器语句
create trigger 触发器名称 before/after insert/update/delete on 表名 for each row
begin
sql语句
end;
这里的after和before表示的是增删改之后还是之前触发的
2:查看触发器语句
show triggers;
3:删除触发器
drop trigger 数据库名.触发器的名字;(如果没有指定数据库的名字,那么默认是当前数据库)
(1)insert触发器
create table user_logs(
opera_text varchar(1000) comment '插入的·内容',
opera_time datetime comment '插入的时间',
opera varchar(20) comment '操作的类型,insert/delete/update'
);
create trigger tb_user_insert_tigger
after insert on sp for each row
begin
insert into user_logs(opera_text, opera_time, opera)
values(concat('插入的名字=',new.name,',插入的年龄=',new.age),now(),'insert');
end;
show triggers;
insert into sp(age, name) values (100,'大魔王');
(2)update触发器
create trigger tb_user_update_trigger
after update on sp for each row
begin
insert into user_logs(opera_text, opera_time, opera) values
(concat('更新前的名字=',old.name,' 更新前的年龄=',old.age,' 更新后的名字=',new.name,' 更新后的年龄=',new.age),now(),'update');
end;
show triggers;
update sp set age=1000 where name='李四';
(3)delete触发器
create trigger tb_user_delete_trigger
after delete on sp for each row
begin
insert into user_logs(opera_text, opera_time, opera)
values(concat('删除的名字=',old.name,' 删除前的年龄=',old.age),now(),'delete');
end;
show triggers;
delete from sp where name='李四';
来源:https://blog.csdn.net/gaoqiandr/article/details/128088975
标签:MySQL,触发器
0
投稿
猜你喜欢
JavaScript在XHTML中的用法详解
2024-04-17 10:11:04
tensorflow基于Anaconda环境搭建的方法步骤
2022-11-04 10:12:58
简单谈谈python中的语句和语法
2023-03-03 12:03:13
解决Jupyter Notebook开始菜单栏Anaconda下消失的问题
2021-04-09 18:33:05
centos源码编译php5 mcrypt模块步骤详解
2024-05-08 10:15:34
Python实现视频中添加音频工具详解
2022-06-03 12:32:28
Oracle跨数据库查询并插入实现原理及代码
2024-01-14 18:52:58
Python面向对象编程中的类和对象学习教程
2023-08-14 06:47:30
全面剖析Python的Django框架中的项目部署技巧第1/2页
2021-09-24 23:46:58
使用mss2sql工具将SqlServer转换为Mysql全记录
2024-01-24 11:59:37
mybatis-plus的sql语句打印问题小结
2024-01-25 11:23:42
Pytorch基本变量类型FloatTensor与Variable用法
2022-10-10 21:14:45
PHP数据库表操作的封装类及用法实例详解
2023-11-12 07:41:23
vue-cli3项目配置eslint代码规范的完整步骤
2024-05-29 22:23:12
python并发编程之多进程、多线程、异步和协程详解
2021-12-10 00:20:35
Django框架文件上传与自定义图片上传路径、上传文件名操作分析
2022-06-09 12:44:28
ASP程序种如何调用DLL文件
2008-01-15 19:12:00
python在地图上画比例的实例详解
2023-06-22 20:54:00
python dataframe NaN处理方式
2022-12-01 18:49:33
pytorch模型部署 pth转onnx的方法
2022-07-05 03:49:04