码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • MySQL---触发器详解


    目录

    一、触发器的介绍

    二、触发器的语法

    (1)insert触发器

    (2)update触发器

    (3)delete触发器


    一、触发器的介绍

    触发器是与表有关的数据库对象,指在insert/update/delete 之前或之后,触发并执行
    触发器中定义的SQL语句集合。触发器的这种特性可以协助应用在数据库端确保数据的
    完整性,日志记录,数据校验等操作。
    使用别名old和new来引用触发器中发生变化的记录内容,这与其它的数据库是相似的。
    现在触发器还只支持行级触发,不支持语句级触发。

    1. 触发器类型 new和old
    2. insert型触发器 new表示将要挥着已经新增的数据
    3. update型触发器 old表示修改之前的数据,new表示将要或者已经修改后的数据
    4. delete型触发器 old表示将要或者已经删除的数据

    二、触发器的语法

    1. 语法:
    2. 1:创建触发器语句
    3. create trigger 触发器名称 before/after insert/update/delete on 表名 for each row
    4. begin
    5. sql语句
    6. end;
    7. 这里的after和before表示的是增删改之后还是之前触发的
    8. 2:查看触发器语句
    9. show triggers;
    10. 3:删除触发器
    11. 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='李四';

     

  • 相关阅读:
    css第九课:文本属性
    目标检测YOLO实战应用案例100讲-基于YOLOv5自适应损失权重的生活垃圾目标检测模型
    Redis代码实践总结(三)——redis持久化
    上海市青少年算法2022年8月月赛(丙组)
    wps文件误删除了怎么恢复?如何找回被误删的WPS文件?
    Docker安装和配置nginx服务
    cookie和session区别
    洛谷P1518 [USACO2.4]两只塔姆沃斯牛 The Tamworth Two
    Spring5学习笔记之整合MyBatis
    Ps:利用 AI 技术创建人像皮肤图层蒙版
  • 原文地址:https://blog.csdn.net/gaoqiandr/article/details/128088975
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号