WEB开发网
开发学院数据库MSSQL Server SQL触发器在保持数据库完整性中的实际应用 阅读

SQL触发器在保持数据库完整性中的实际应用

 2008-09-02 09:59:12 来源:WEB开发网   
核心提示:1.触发器概述 触发器是SQL Server数据库应用中一个重要工具,是一种特殊类型的存储过程,SQL触发器在保持数据库完整性中的实际应用,应用非常广泛,一般存储过程主要通过存储过程名而被直接调用,从受影响的表中删除的行的副本将被放置到deleted表中,同理当触发insert触发器后,触发器则是通过事件触发执行,触发

1.触发器概述

触发器是SQL Server数据库应用中一个重要工具,是一种特殊类型的存储过程,应用非常广泛。一般存储过程主要通过存储过程名而被直接调用,触发器则是通过事件触发执行。触发器基于一个表来创建并和一个或多个数据修改操作(插入、更新或删除)相关联,可视作表的一部分。触发器与数据库中的表紧密相关,比如当对表执行insert、update或delete操作时,触发器就会自动执行。

SQL Server包括两大类触发器:DML 触发器和 DDL 触发器。其中DDL 触发器是 SQL Server 2005 的新增功能,当服务器或数据库中发生数据定义语言 (DDL) 事件时将调用该触发器;DML 触发器是指当数据库中发生数据操作语言 (DML) 事件时被调用。DML 事件包括在指定表或视图中修改数据的 insert、update或 delete 语句。DML 触发器可以查询其他表,还可以包含复杂的 Transact-SQL 语句。DML 触发器用于在数据被修改时强制执行业务规则,以及扩展 Microsoft SQL Server 2005 约束、默认值和规则的完整性检查逻辑。本文中所讲述的触发器主要是指DML 触发器。

DML触发器包括三种类型:AFTER 触发器、INSTEAD OF 触发器、CLR 触发器。在执行了 insert、update 或 delete 语句操作之后将会执行 AFTER 触发器,本文将以AFTER触发器为例来讲述触发器在保持数据完整性中的应用。其创建语法如下:

  create TRIGGER trigger_name
  
  ON table_name
  
  AFTER {[insert][,][update][,][delete]}}
  
  AS
  
  Sql_statements
  
  [RETURN]

在触发器的应用中,我们通常会用到两个特殊的表:inserted表和deleted表。它们都是针对当前触发器的局部表。这两个表与触发器所在表的结构完全相同,而且总是存储在高速缓存中。当触发delete触发器后,从受影响的表中删除的行的副本将被放置到deleted表中。同理当触发insert触发器后,inserted表中保存的是刚被插入的数据行的一个副本。

1 2 3 4 5  下一页

Tags:SQL 触发器 保持

编辑录入:爽爽 [复制链接] [打 印]
赞助商链接