【MySQL】——断言和触发器

💻博主现有专栏:

                C51单片机(STC89C516),c语言,c++,离散数学,算法设计与分析,数据结构,Python,Java基础,MySQL,linux,基于HTML5的网页设计及应用,Rust(官方文档重点总结),jQuery,前端vue.js,Javaweb开发,Python机器学习等
🥏主页链接:

                Y小夜-CSDN博客

目录

🎯断言

🎃创建断言的语句格式

🎃删除断言的语句

🎯定义触发器

🎯激活触发器

🎯删除触发器


🎯断言

  • SQL中,可以使用 CREATE ASSERTION语句,通过声明性断言来指定更具一般性的约束。
  • 可以定义涉及多个表的或聚集操作的比较复杂的完整性约束。
  • 断言创建以后,任何对断言中所涉及的关系的操作都会触发关系数据库管理系统对断言的检查,任何使断言不为真值的操作都会被拒绝执行

🎃创建断言的语句格式

  • CREATE ASSERTION<断言名><CHECK 子句>
  • 每个断言都被赋予一个名字,<CHECK 子句>中的约束条件与WHERE子句的条件表达式类似。

🎃删除断言的语句

  • DROP ASSERTION <断言名>;
  • 如果断言很复杂,则系统在检测和维护断言的开销较高,这是在使用断言时应该注意的

🎯定义触发器

CREATE TRIGGER语法格式

       CREATE TRIGGER <触发器名>

         {BEFORE | AFTER} <触发事件> ON <表名>

       REFERENCING NEW|OLD ROW AS<变量>

       FOR EACH  {ROW | STATEMENT}

       [WHEN <触发条件>]<触发动作体>

         触发器又叫做事件-条件-动作(event-condition-action)规则。 当特定的系统事件发生时,对规则的条件进行检查,如果条件成立则执 行规则中的动作,否则不执行该动作。规则中的动作体可以很复杂,通 常是一段SQL存储过程。

        触发器类型

  • 行级触发器(FOR EACH ROW)
  • 语句级触发器(FOR EACH STATEMENT)

如果是语句级触发器,那么执行完该语句后,触发动作只发生一次

如果是行级触发器,触发动作将执行1000次

定义触发器的语法说明

(1)表的拥有者才可以在表上创建触发器

(2)触发器名

  • 触发器名可以包含模式名,也可以不包含模式名
  • 同一模式下,触发器名必须是唯一的
  • 触发器名和表名必须在同一模式下

(3)表名

  • 触发器只能定义在基本表上,不能定义在视图上
  • 当基本表的数据发生变化时,将激活定义在该表上相应触    发事件的触发器

(4)触发事件

触发事件可以是INSERT、DELETE或UPDATE

  •    也可以是这几个事件的组合
  • 还可以UPDATE OF<触发列,...>,即进一步指明修改哪些列时激活触发器

AFTER/BEFORE是触发的时机

  • AFTER表示在触发事件的操作执行之后激活触发器
  • BEFORE表示在触发事件的操作执行之前激活触发器

(5)触发条件

  • 触发器被激活时,只有当触发条件为真时触发动作体才执行;否则触发动作体不执行。
  • 如果省略WHEN触发条件,则触发动作体在触发器激活后立即执行

(7)触发动作体 触发动作体可以是一个匿名过程块,也可以是对已创建存储过程的调用

  • 如果是行级触发器,用户都可以在过程体中使用NEW和OLD引用事件之后的新值和事件之前的旧值
  • 如果是语句级触发器,则不能在触发动作体中使用NEW或OLD进行引用
  • 如果触发动作体执行失败,激活触发器的事件就会终止执行,触发器的目标表或触发器可能影响的其他对象不发生任何变化

注意:不同的RDBMS产品触发器语法各不相同

🎯激活触发器

触发器的执行,是由触发事件激活的,并由数据库服务器自动执行

一个数据表上可能定义了多个触发器,遵循如下的执行顺序:

  • (1) 执行该表上的BEFORE触发器;
  • (2) 激活触发器的SQL语句;
  • (3) 执行该表上的AFTER触发器。

🎯删除触发器

  • 删除触发器的SQL语法:

     DROP TRIGGER <触发器名> ON <表名>;

  • 触发器必须是一个已经创建的触发器,并且只能由具有相应权限的用户删除。
  • 27
    点赞
  • 29
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 13
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 13
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Y小夜

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值