zoukankan      html  css  js  c++  java
  • 数据库(十)之触发器

    触发器
     什么是触发器?
     触发器是一个在修改表中的数据时执行的存储过程。通常通过创建触发器来实现不同表中的逻辑
     相关数据的引用完整性或一致性。由于用户不能绕过触发器,所以可以用它来强制实施复杂的业
     务规则,以确保数据的完整性。
     
     触发器不同于存储过程。触发器主要是通过时间进行触发而被执行的,而存储过程可以通过存储
     过程名字而被直接调用。当对某一表进行诸如update,insert,delete这些操作时,SLQ Server
     就会自动执行触发器所定义的SQL语句,从而确保对数据的处理必须符合由这些SQL语句定义的
     规则。
     
     为什么使用触发器?
      触发器自动执行,它们在表的数据作了任何修改(比如手工输入或者使用程序采集的操作)之
     后立即激活。
      触发器可以通过数据库中的相关表进行层叠更改。这比直接把代码写在前台的做法更合理更
     安全。
      触发器可以强制限制,这些限制比用check约束锁定义的更复杂。与check约束不同的是,
     触发器可以引用其他表中的列。
     
     触发器种类
     DDL触发器:
      DDL触发器当服务器或者数据中发送数据定义语言(DDL)事件时将被调用。如果执行以下操作
      ,可以使用DDL触发器。
      要防止对数据库架构进行某些更改。
      希望数据库中发生某种情况以响应数据库架构中的更改。
      要记录数据库架构中的更改或事件。
      
     DML触发器
      DML触发器是当数据库服务器中发生数据操作语言(DML)事件时要执行的操作。通常所说的DML
      触发器主要包括三种:insert触发器,update触发器,delete触发器。DML触发器可以查询其
      他表,还可以包含复杂的T_SQL语句。将触发器和触发它的语句作为可在触发器内回滚的单个
      事务对待。如果检查到错误,则整个事务自动回滚。
     
    创建insert触发器
     语法格式:
      create trigger trigger_name
      on{table | view}
      {
       {
        {for | after | instead of}
        {[delete][,][insert][,][update]}
        as
         sql_statement
       }
      }
      
     例子:
      create trigger T_addnum
      on 学生信息
      for insert
      as
       update 班级信息 set 班级人数 = 班级人数 + 1
       where 班级编号 = (select 所属班级 from inserted)
       
    创建delete触发器
     create trigger T_delete
     on 教师信息
     for delete
     as
      select * from deleted
      
    创建update触发器
     create trigger T_update
     on 教师信息
     for update
     as
      if(update(姓名) or (性别))
      begin
       print '事务不能被处理,基础数据不能修改'
       rollback transaction
      end
      else
      begin
       print '数据修改成功'
      end
      
    创建DDL触发器  
     语法格式:
      create trigger trigger_name
      on {all server | database}
      with encryption
      {for|after{event_type}}
      as
       sql_statement
      
     例子:
      create table T_notDelete
      on database
      for drop_table, alter_table
      as
       print 'no admission'
       rollback
       
    管理触发器  
     修改触发器:
      alter trigger trigger_name
      on {all server | database}
      with encryption
      {for|after{event_type}}
      as
       sql_statement
      
     禁用触发器
      alter table 员工信息
      disable trigger t_add
      
     启用触发器
      alter table 员工信息
      enable trigger t_add
      
     删除触发器
      drop trigger t_add
      
    嵌套触发器
     create trigger t_add
     on 员工信息
     for inserte
     as
      update 部门信息 set 部门人数 = 部门人数 + 1
      where 部门编号 = (select 所在部门编号 from inserted)
      
     create trigger t_delete
     on 新员工信息
     for delete
     as
      insert into 员工信息(员工编号, 员工姓名, 所在部门编号, 所任职位, 性别)
      select 员工编号, 员工姓名, 所在部门编号, 所任职位, 性别
      from deleted
      
    递归触发器
     任何触发器都可以包含影响同一个表或另一个表的update,insert或delete语句。如果启用递
     归触发器选项,那么改变表中数据的触发器,通过递归执行就可以再次出发自己。在数据库
     创建时,默认情况下递归触发器选项时禁用的,但可以使用alter database语句来启用它。
     
     递归触发器具有复杂特性,可以用它来解决诸如自引用这样的复杂关系。使用递归触发器时,
     需要考虑以下的事项和原则:
      递归触发器很复杂,必须经过有条理的设计和全面的测试。
      在任意点的数据修改会触发一系列触发器。尽管提供处理复杂关系的能力,但是如果表要
      求以特定的顺序更新用户的表时,使用递归触发器就会产生问题。
      所有触发器一起构成一个大事件。任何触发器中的任何位置上的rollback命令都将取消
      所有数据输入。所有数据均被擦除,并且无任何数据将被放到表中。
      触发器最多只能递归16层。换句话说,如果递归链中的第16个触发器激活了第17个触发器
      则结果与发布rollback命令一样,所有数据被擦除。

  • 相关阅读:
    python内置函数
    conda和anaconda的区别
    闭包,装饰器,property
    【模板】大数乘法(51nod 1027)
    51nod 1791 合法括号子段
    51nod 1419 最小公倍数挑战
    51nod 1241 特殊的排序
    51nod 1090 3个数和为0
    【模板】51nod 1051 最大子矩阵和
    51nod 1267 4个数和为0
  • 原文地址:https://www.cnblogs.com/ZGreMount/p/8612304.html
Copyright © 2011-2022 走看看