一 触发器是一种特殊的存储过程﹐它不能被显式地调用﹐而是在往表中插入记录﹑更新记录或者删除记录时被自动地激活。所以触发器可以用来实现对表实施复杂的完整性约束。
二 SQL Server为每个触发器都创建了两个专用表:Inserted表和Deleted表。这两个表由系统来维护﹐它们存在于内存中而不是在数据库中。这两个表的结构总是与被该触发器作用的表的结构相同。触发器执行 完成后﹐与该触发器相关的这两个表也被删除。
Deleted表存放由于执行Delete或Update语句而要从表中删除的所有行。
Inserted表存放由于执行Insert或Update语句而要向表中插入的所有行。
三 Instead of 和 After触发器
SQL Server2000提供了两种触发器﹕Instead of 和After 触发器。这两种触发器的差别在于他们被激活的不同
Instead of触发器用于替代引起触发器执行的T-SQL语句。除表之外﹐Instead of 触发器也可以用于视图﹐用来扩展视图可以支持的更新操作。
After触发器在一个Insert,Update或Deleted语句之后执行﹐进行约束检查等动作都在After触发器被激活之前发生。After触发器只能用于表。
一个表或视图的每一个修改动作(insert,update和delete)都可以有一个instead of 触发器﹐一个表的每个修改动作都可以有多个After触发器。
四 触发器的执行过程
如果一个Insert﹑update或者delete语句违反了约束﹐那么After触发器不会执行﹐因为对约束的检查是在After触发器被激发之前发生的。所以After触发器不能超越约束。
Instead of 触发器可以取代激发它的操作来执行。它在Inserted表和Deleted表刚刚建立﹐其它任何操作还没有发生时被执行。因为Instead of 触发器在约束之前执行﹐所以它可以对约束进行一些预处理。
五 使用T-SQL语句来创建触发器
基本语句如下﹕
create trigger trigger_name
on {table_name | view_name}
{for | After | Instead of }
[ insert, update,delete ]
as
sql_statement
六 删除触发器:
基本语句如下:
drop trigger trigger_name
七 查看数据库中已有触发器:
-- 查看数据库已有触发器
use jxcSoftware
go
select * from sysobjects where xtype='TR'
-- 查看单个触发器
exec sp_helptext '触发器名'
八 修改触发器:
基本语句如下:
alter trigger trigger_name
on {table_name | view_name}
{for | After | Instead of }
[ insert, update,delete ]
as
sql_statement
九 相关示例
1.在Orders表中建立触发器﹐当向Orders表中插入一条订单记录时﹐检查goods表的货品状态status是否为1(正在整理)﹐是﹐则不能往Orders表加入该订单。
create trigger orderinsert
on orders
after insert
as
if (select status from goods,inserted
where goods.name=inserted.goodsname)=1
begin
print 'the goods is being processed'
print 'the order cannot be committed'
rollback transaction --回滚﹐避免加入
end
2.在Orders表建立一个插入触发器﹐在添加一条订单时﹐减少Goods表相应的货品记录中的库存。
create trigger orderinsert1
on orders
after insert
as
update goods set storage=storage-inserted.quantity
from goods,inserted
where
goods.name=inserted.goodsname
3.在Goods表建立删除触发器﹐实现Goods表和Orders表的级联删除。
create trigger goodsdelete
on goods
after delete
as
delete from orders
where goodsname in
(select name from deleted)
4.在Orders表建立一个更新触发器﹐监视Orders表的订单日期(OrderDate)列﹐使其不能手工修改.
create trigger orderdateupdate
on orders
after update
as
if update(orderdate)
begin
raiserror(' orderdate cannot be modified',10,1)
rollback transaction
end
5.在Orders表建立一个插入触发器﹐保证向Orders表插入的货品名必须要在Goods表中一定存在。
create trigger orderinsert3
on orders
after insert
as
if (select count(*) from goods,inserted where goods.name=inserted.goodsname)=0
begin
print ' no entry in goods for this order'
rollback transaction
end
6.Orders表建立一个插入触发器,保证向Orders表插入的货品信息要在Order表中添加
alter trigger addOrder
on Orders
for insert
as
insert into Order
select inserted.Id, inserted.goodName,inserted.Number from inserted
相关推荐
SQL_Server 触发器创建、删除、修改、查看示例教程 SQL Server 触发器是一种特殊的存储过程,它不能被显式地调用,而是在往表中插入记录、更新记录或者删除记录时被自动地激活。所以触发器可以用来实现对表实施...
1. 触发器的启用与禁用:可以使用ALTER TRIGGER语句来更改触发器的启用状态。例如,要禁用上述触发器: ```sql ALTER TRIGGER trg_Employee_Salary_Update ON Employee DISABLE; ``` 要再次启用: ```sql ALTER ...
### SQL Server 触发器创建、删除、修改、查看示例 #### 一、概述 在 SQL Server 中,触发器是一种特殊类型的存储过程,它自动执行响应数据更改(如 INSERT、UPDATE 或 DELETE)操作。触发器可以确保数据完整性,...
使用`SELECT * FROM sys.triggers`可以查看所有触发器,`ALTER TRIGGER`用于修改已存在的触发器,`DROP TRIGGER`用于删除触发器。 8. **注意事项**: - 触发器可能导致性能下降,因为它们增加了数据库操作的复杂...
当使用下面的一种或多种数据修改操作在指定表中对数据进行修改时,触发器会生效:UPDATE、INSERT 或DELETE。触发器可以查询其它表,而且可以包含复杂的 SQL 语句。它们主要用于强制复杂的业务规则或要求。 触发器的...
可以通过ALTER TRIGGER修改触发器,DROP TRIGGER删除触发器,EXEC sp_helptrigger显示触发器的详细信息。 五、注意事项 1. 触发器可能导致性能问题,因为它们增加了数据库的复杂性,可能引发递归触发器链,因此需...
通过使用SQL语句创建触发器,数据库管理员和开发人员可以有效地控制数据的修改过程,确保数据的完整性和一致性。无论是简单的数据验证还是复杂的业务逻辑,触发器都能提供一种强大而灵活的机制。然而,触发器的设计...
本章节主要讲述了 SQL Server 中的存储过程和触发器的概念、类型、创建、使用和优点等。 存储过程概述 存储过程是 SQL Server 服务器上的一组预编译的 Transact-SQL 语句,用于完成某项任务。它可以接受参数、返回...
触发器是数据库系统中的重要组件,用于实现复杂的业务规则和数据完整性约束,当用户试图更改数据时,它们可以扩展SQL的功能。以下是对SQL数据库触发器的详细讲解: 1. 触发器类型: - INSERT触发器:在向表中插入...
在SQL中,触发器是一种非常重要的数据库对象,它允许开发者定义特定的数据操作行为,这些行为会在数据更改(如INSERT、UPDATE或DELETE)时自动执行。触发器主要用于维护数据的完整性和一致性,它弥补了主键和外键...
学习SQL Server 2005的触发器,建议从基础概念开始,理解触发器的工作原理和使用场景,然后通过实际示例学习如何创建、修改和删除触发器。同时,了解如何调试触发器并解决可能出现的问题也非常重要。 综上所述,...
为了查看触发器的定义,可以使用`sp_helptext`系统存储过程,或者在SQL Server企业管理器中通过“所有任务” -> “管理触发器”来查看和管理触发器。要查看当前数据库的所有触发器,可以执行如下SQL语句: ```sql ...
SQL Server 触发器创建、删除、修改、查看 SQL Server 触发器是一种特殊的存储过程,它不能被显式地调用,而是在往表中插入记录、更新记录或者删除记录时被自动地激活。因此触发器可以用来实现对表实施复杂的完整性...
### SQL Server 创建触发器实现级联删除 在数据库管理中,触发器是一种特殊类型的存储过程,它被设计为响应特定的事件(如插入、更新或删除数据)而自动执行。本文将详细介绍如何在 SQL Server 中创建一个触发器来...
- DELETE触发器示例:创建一个触发器,当从`Categories`表中删除一个类别时,更新所有属于该类别的`Products`表记录,将`Discontinued`字段设置为1,表示产品已停售。 总的来说,SQL Server中的触发器是强大的工具...
在SQL Server中,触发器是一种特殊的存储过程,它在特定的数据库操作(如INSERT、UPDATE、DELETE)发生时自动执行,以实现复杂的数据完整性规则或业务逻辑。本篇将深入探讨触发器的基本概念、类型、分类及如何实现...
触发器是SQL Server中一种特殊的存储过程,其特点在于不能被显式地调用,而是当对特定表进行数据操作(如插入、更新或删除)时自动激活。通过这种方式,触发器能够帮助实现复杂的业务逻辑和数据完整性约束。 #### ...
在SQL Server中,触发器是一种特殊类型的存储过程,它被设计为响应对特定表的数据修改(如INSERT、UPDATE或DELETE操作)而自动执行。触发器可以用来确保数据完整性,并且可以在记录被插入、更新或删除时执行复杂的...
7. 修改或阻止原SQL语句执行:在某些情况下,触发器可以阻止不合适的操作,如防止关键数据被删除。 总的来说,SQL Server 2005的触发器是数据库管理系统中不可或缺的一部分,它们允许开发人员扩展数据库的逻辑,...