• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • MsSql
  • Mysql
  • oracle
  • MariaDB
  • DB2
  • SQLite
  • PostgreSQL
  • MongoDB
  • Redis
  • Access
  • 数据库其它
  • sybase
  • HBase
您的位置:首页 > 数据库 >Mysql > MySQL delete触发器(删除)用法详解

MySQL delete触发器(删除)用法详解

作者:匿名 字体:[增加 减小] 来源:互联网 时间:2018-12-05

匿名通过本文主要向大家介绍了MySQL,delete,触发器等相关知识,希望本文的分享对您有所帮助
DELETE触发器

触发器(trigger)是SQL server 提供给程序员和数据分析员来保证数据完整性的一种方法,它是与表事件相关的特殊的存储过程,它的执行不是由程序调用,也不是手工启动,而是由事件来触发,比如当对一个表进行操作( insert,delete, update)时就会激活它执行。触发器经常用于加强数据的完整性约束和业务规则等。 触发器可以从 DBA_TRIGGERS ,USER_TRIGGERS 数据字典中查到。SQL3的触发器是一个能由系统自动执行对数据库修改的语句。

触发器可以查询其他表,而且可以包含复杂的SQL语句。它们主要用于强制服从复杂的业务规则或要求。例如:您可以根据客户当前的帐户状态,控制是否允许插入新订单。

DELETE 触发器在 DELETE 语句执行之前或之后执行。需要知道以下两点:

1.在 DELETE 触发器代码内,你可以引用一个名为 OLD 的虚拟表,访问被删除的行;

2.OLD 中的值全都是只读的,不能更新。下面的例子演示使用 OLD 保存将要被删除的行到一个存档表中:

输入:

create trigger deleteorder before delete on orders for each row
begin
insert into archive_orders(order_num,order_date,cust_id)
values(old.order_num,old.order_date,old.cust_id);
end;

分析:在任意订单被删除前将执行此触发器。它使用一条 INSERT 语句将 OLD 中的值(要被删除的订单)保存到一个名为 archive_orders 的存档表中(为实际使用这个例子,你需要用与 orders 相同的列创建一个名为 archive_orders 的表)。

使用 BEFORE DELETE 触发器的优点(相对于 AFTER DELETE 触发器来说)为,如果由于某种原因,订单不能存档, DELETE 本身将被放弃。

多语句触发器 正如所见,触发器 deleteorder 使用 BEGIN 和END 语句标记触发器体。这在此例子中并不是必需的,不过也没有害处。使用 BEGIN END 块的好处是触发器能容纳多条SQL语句(在 BEGIN END块 中一条挨着一条)。

【相关推荐】

1. mysql免费视频教程

2. MySQL中insert触发器(插入)详解

3. mysql触发器简介及如何创建和删除触发器

4. MySQL使用字符集和校对顺序使用教程

5. MySQL字符集和校对顺序简介

以上就是MySQL delete触发器(删除)用法详解的详细内容,更多请关注微课江湖其它相关文章!

分享到:QQ空间新浪微博腾讯微博微信百度贴吧QQ好友复制网址打印

您可能想查找下面的文章:

  • 分享下mysql各个主要版本之间的差异
  • MySQL essential版本和普通版本有什么区别?
  • redhat 5.4下安装MYSQL全过程
  • 如何用SQL命令查看Mysql数据库大小
  • 解析mysql中如何获得数据库的大小
  • 解析mysql修改为utf8后仍然有乱码的问题
  • 5个常用的MySQL数据库管理工具详细介绍
  • 解析在MySQL里创建外键时ERROR 1005的解决办法
  • 解析远程连接管理其他机器上的MYSQL数据库
  • mysql 精简过程(删除一些文件)

相关文章

  • 2017-05-11MySQL优化之表结构优化的5大建议(数据类型选择讲的很好)
  • 2018-12-05MSSQL数据库安全设置方法!
  • 2017-05-11Mysql 数字类型转换函数
  • 2018-12-05MySQL之-基本操作的代码示例汇总
  • 2018-12-05数据库的自动还原失败如何解决
  • 2018-12-05模糊查询的通用存储过程
  • 2018-12-05SQLServer转MYSQL的方法详解
  • 2018-12-05关于MYSQL 远程登录的授权方法 命令
  • 2018-12-05浅谈MySql的存储引擎(表类型)
  • 2018-12-05Java中获取mysql连接三种方法介绍(图)

文章分类

  • MsSql
  • Mysql
  • oracle
  • MariaDB
  • DB2
  • SQLite
  • PostgreSQL
  • MongoDB
  • Redis
  • Access
  • 数据库其它
  • sybase
  • HBase

最近更新的内容

    • mysql备份与恢复详解
    • sqlserver中重复数据值只取一条的sql语句
    • MySQL 分区表 partition线上修改分区字段,后续进一步学习partition (1)
    • CentOS6.4上使用yum安装mysql_MySQL
    • MySQL死锁与日志分析
    • 常用mysql优化sql语句查询方法汇总
    • MySQL异地增量备份
    • 排名前十的SQL和NoSQL数据库
    • mysql获得60天前unix时间的方法
    • 利用Xtrabackup工具备份及恢复(MySQL DBA的必备工具)

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有