经验首页 前端设计 程序设计 Java相关 移动开发 数据库/运维 软件/图像 大数据/云计算 其他经验
当前位置:技术经验 » 数据库/运维 » MySQL » 查看文章
Mysql中的触发器定义与使用
来源:jb51  时间:2022/12/2 10:59:02  对本文有异议

一、触发器的介绍

触发器是与表有关的数据库对象,指在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触发器

  1. create table user_logs(
  2. opera_text varchar(1000) comment '插入的·内容',
  3. opera_time datetime comment '插入的时间',
  4. opera varchar(20) comment '操作的类型,insert/delete/update'
  5. );
  6. create trigger tb_user_insert_tigger
  7. after insert on sp for each row
  8. begin
  9. insert into user_logs(opera_text, opera_time, opera)
  10. values(concat('插入的名字=',new.name,',插入的年龄=',new.age),now(),'insert');
  11. end;
  12. show triggers;
  13. insert into sp(age, name) values (100,'大魔王');

(2)update触发器

  1. create trigger tb_user_update_trigger
  2. after update on sp for each row
  3. begin
  4. insert into user_logs(opera_text, opera_time, opera) values
  5. (concat('更新前的名字=',old.name,' 更新前的年龄=',old.age,' 更新后的名字=',new.name,' 更新后的年龄=',new.age),now(),'update');
  6. end;
  7. show triggers;
  8. update sp set age=1000 where name='李四';

(3)delete触发器

  1. create trigger tb_user_delete_trigger
  2. after delete on sp for each row
  3. begin
  4. insert into user_logs(opera_text, opera_time, opera)
  5. values(concat('删除的名字=',old.name,' 删除前的年龄=',old.age),now(),'delete');
  6. end;
  7. show triggers;
  8. delete from sp where name='李四';

到此这篇关于Mysql中的触发器定义与使用的文章就介绍到这了,更多相关MySQL触发器内容请搜索w3xue以前的文章或继续浏览下面的相关文章希望大家以后多多支持w3xue!

 友情链接:直通硅谷  点职佳  北美留学生论坛

本站QQ群:前端 618073944 | Java 606181507 | Python 626812652 | C/C++ 612253063 | 微信 634508462 | 苹果 692586424 | C#/.net 182808419 | PHP 305140648 | 运维 608723728

W3xue 的所有内容仅供测试,对任何法律问题及风险不承担任何责任。通过使用本站内容随之而来的风险与本站无关。
关于我们  |  意见建议  |  捐助我们  |  报错有奖  |  广告合作、友情链接(目前9元/月)请联系QQ:27243702 沸活量
皖ICP备17017327号-2 皖公网安备34020702000426号