`
baobeituping
  • 浏览: 1071119 次
  • 性别: Icon_minigender_1
  • 来自: 长沙
社区版块
存档分类
最新评论

sqlserver2000触发器学习

 
阅读更多

1、

Sql代码 复制代码 收藏代码
  1. createtrigger tr_name
  2. ontable/view
  3. {for | after | insteadof } [update][,][insert][,][delete]
  4. [with encryption]
  5. as {batch | if update (col_name) [{and|or} update (col_name)] }
create trigger tr_name 
on table/view 
{for | after | instead of } [update][,][insert][,][delete] 
[with encryption] 
as {batch | if update (col_name) [{and|or} update (col_name)] } 

说明:
  1 tr_name :触发器名称
  2 on table/view :触发器所作用的表。一个触发器只能作用于一个表
  3 for 和after :同义
  4 after 与instead of :sql 2000新增项目afrer 与 instead of 的区别
    After
      在触发事件发生以后才被激活,只可以建立在表上
    Instead of
      代替了相应的触发事件而被执行,既可以建立在表上也可以建立在视图上
  5 insert、update、delete:激活触发器的三种操作,可以同时执行,也可选其一
  6 if update (col_name):表明所作的操作对指定列是否有影响,有影响,则激活触发器。此外,因为delete 操作只对行有影响,
所以如果使用delete操作就不能用这条语句了(虽然使用也不出错,但是不能激活触发器,没意义)。
  7 触发器执行时用到的两个特殊表:deleted ,inserted
    deleted 和inserted 可以说是一种特殊的临时表,是在进行激活触发器时由系统自动生成的,其结构与触发器作用的表结构是一样的,只是存放 的数据有差异。
  8 说明deleted 与inserted 数据的差异
    deleted 与inserted 数据的差异
    Inserted 存放进行insert和update 操作后的数据
    Deleted 存放进行delete 和update操作前的数据
    注意:update 操作相当于先进行delete 再进行insert ,所以在进行update操作时,修改前的数据拷贝一条到deleted 表中,修改后的数据在存到触发器作用的表的同时,也同时生成一条拷贝到insered表中

例子:

Sql代码 复制代码 收藏代码
  1. if exists(selectnamefrom sysobjects where xtype='tr'andname='tri_updateStudent')
  2. begin
  3. droptrigger tri_UpdateStudent
  4. end
  5. go
  6. createtrigger tri_UpdateStudent
  7. on dbo.student
  8. forupdate
  9. as
  10. if update(Sage)
  11. begin
  12. update student set sage=s.sage+d.sage from student s,deleted d where s.studentid=d.studentid
  13. end
  14. go
if exists(select name from sysobjects where xtype='tr' and name='tri_updateStudent')
begin
    drop trigger tri_UpdateStudent
end
go
create trigger tri_UpdateStudent
    on dbo.student
    for update
as
    if update(Sage)
    begin
       update student set sage=s.sage+d.sage from student s,deleted d where s.studentid=d.studentid
    end
go

二﹕ 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 触发器在约束之前执行﹐所以它可以对约束进行一些预处理。

六﹕删除触发器:

基本语句如下﹕

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表加入该订单。

Sql代码 复制代码 收藏代码
  1. createtrigger orderinsert
  2. on orders
  3. afterinsert
  4. as
  5. if (select status from goods,inserted
  6. where goods.name=inserted.goodsname)=1
  7. begin
  8. print 'the goods is being processed'
  9. print 'the order cannot be committed'
  10. rollbacktransaction--回滚﹐避免加入
  11. end
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表相应的货品记录中的库存。

Sql代码 复制代码 收藏代码
  1. createtrigger orderinsert1
  2. on orders
  3. afterinsert
  4. as
  5. update goods set storage=storage-inserted.quantity
  6. from goods,inserted
  7. where
  8. goods.name=inserted.goodsname
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表的级联删除。

Sql代码 复制代码 收藏代码
  1. createtrigger goodsdelete
  2. on goods
  3. afterdelete
  4. as
  5. deletefrom orders
  6. where goodsname in
  7. (selectnamefrom deleted)
create trigger goodsdelete
on goods
after delete
as
delete from orders
where goodsname in
(select name from deleted)

4﹕在Orders表建立一个更新触发器﹐监视Orders表的订单日期(OrderDate)列﹐使其不能手工修改.

Sql代码 复制代码 收藏代码
  1. createtrigger orderdateupdate
  2. on orders
  3. afterupdate
  4. as
  5. if update(orderdate)
  6. begin
  7. raiserror(' orderdate cannot be modified',10,1)
  8. rollbacktransaction
  9. end
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表中一定存在。

Sql代码 复制代码 收藏代码
  1. createtrigger orderinsert3
  2. on orders
  3. afterinsert
  4. as
  5. if (selectcount(*) from goods,inserted where goods.name=inserted.goodsname)=0
  6. begin
  7. print ' no entry in goods for this order'
  8. rollbacktransaction
  9. end
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表中添加

Sql代码 复制代码 收藏代码
  1. altertrigger addOrder
  2. on Orders
  3. forinsert
  4. as
  5. insertintoOrder
  6. select inserted.Id, inserted.goodName,inserted.Number from inserted
分享到:
评论

相关推荐

    SqlServer2000触发器

    对于SQL Server 2000触发器的深入学习,可以访问博文链接:[https://lytlove68.iteye.com/blog/677675](https://lytlove68.iteye.com/blog/677675),其中可能包含了更多实用案例和详细解释。 综上所述,SQL Server ...

    sqlserver 触发器学习(实现自动编号)

    在SQL Server中,触发器是一种特殊的存储过程,它在特定的数据库操作(如INSERT、UPDATE、DELETE)发生时自动执行,以实现复杂的数据完整性规则或业务逻辑。本篇将深入探讨触发器的基本概念、类型、分类及如何实现...

    与SQL Server 2000触发器相关的二个临时表的辨析.pdf

    理解这两个临时表的机制是深入学习SQL Server触发器的基础。 首先,当我们讨论关于SQL Server触发器的操作时,主要包括INSERT、UPDATE和DELETE三种类型。触发器是一种特殊类型的存储过程,它在对表执行INSERT、...

    sql server 2000 试题汇编答案

    本压缩包文件"sql server 2000 试题汇编答案"显然是针对SQL Server 2000的练习题集及解答,旨在帮助学习者提升对SQL Server 2000的理解和操作技能。以下将详细探讨SQL Server 2000的相关知识点: 1. **SQL Server ...

    SQL Server 2000触发器技术及应用.pdf

    从文档给出的内容中,我们可以看到触发器在SQL Server 2000中的重要性,以及如何设计和使用触发器来解决复杂的数据完整性问题。触发器为数据库管理员和开发者提供了一种灵活的机制,能够在数据操作层面增强数据的...

    第05节:SQLServer触发器Demo源代码.rar

    这个资源“第05节:SQLServer触发器Demo源代码.rar”很可能是包含了一个C#项目,该项目演示了如何在应用程序中创建、使用和管理SQL Server触发器。通过学习和理解这些示例代码,开发者可以更好地掌握在C#环境中操作...

    SQL Server 2000触发器运行机制的逻辑分析.pdf

    在SQL Server 2000中,触发器的运行机制较为复杂,特别是对初学者而言。触发器可以分为两种类型:AFTER触发器和INSTEAD OF触发器。 AFTER触发器在数据变动操作(INSERT、UPDATE、DELETE)已经完成之后被激发。它们...

    SQL SERVER 触发器视频讲解

    在SQL Server中,触发器是一种特殊的存储过程,它在数据库中的特定事件发生时自动执行,如数据插入、更新或删除操作。本视频讲解将深入探讨触发器的创建、编辑、修改及其功能,帮助用户更好地理解和应用这些技术。 ...

    16.sql.server.2005.触发器 16.sql.server.2005.触发器

    学习SQL Server 2005的触发器,建议从基础概念开始,理解触发器的工作原理和使用场景,然后通过实际示例学习如何创建、修改和删除触发器。同时,了解如何调试触发器并解决可能出现的问题也非常重要。 综上所述,...

    SQL Server常用操作触发器、存储过程.rar

    在SQL Server中,触发器和存储过程是两个重要的数据库编程...在"SQL Server常用操作触发器、存储过程.rar"这个压缩包中,你将找到关于这两个主题的详细教程,通过学习和实践,你将能够更好地掌握它们的用法和应用场景。

    SQL Server 2000试题汇编第一单元答案

    本题目汇编聚焦于SQL Server 2000的基础知识,旨在帮助学习者巩固和提升对这个系统的理解和应用能力。 一、SQL Server 2000概述 SQL Server 2000是微软数据库平台的一个里程碑,它引入了诸多新特性和改进,如增强的...

    Microsoft SQL Server 2000 基础系列课程.rar

    【标题】"Microsoft SQL Server 2000 基础系列课程.rar" 提供的是一个针对初学者的全面教程,旨在帮助学习者掌握SQL Server 2000这一关系数据库管理系统的基础知识。SQL Server 2000是微软公司推出的一款强大的...

    SQL Server2000中文版基础教程-源代码

    本教程的源代码部分可能包含示例数据库结构、SQL查询示例、存储过程等,通过实践这些代码,学习者可以更直观地理解和应用上述知识点,从而快速掌握SQL Server 2000的基础操作和管理。在学习过程中,不断实践和解决...

    SQL Server 2000 学习教程

    《SQL Server 2000 学习教程》是一份专为初学者设计的数据库管理教程,它深入浅出地介绍了Microsoft SQL Server 2000这一经典版本的核心概念、功能和操作。作为一款关系型数据库管理系统,SQL Server 2000在企业级...

    SQL SERVER2000实用教程 蒋文沛主编课件、实例代码及习题答案

    《SQL SERVER2000实用教程》是由蒋文沛主编的一部教材,主要针对21世纪高等职业教育计算机技术规划,旨在帮助学生和学习者掌握SQL Server 2000这一数据库管理系统的基础知识和实际操作技能。该教程包含了丰富的课件...

    SQLSERVER2000数据库例子

    标题"SQLSERVER2000数据库例子"指的是这个压缩包包含的是SQL Server 2000的一些示例数据库,这些示例通常用于教学、学习和测试环境,帮助用户了解如何设计、创建和管理数据库。这些例子可以展示SQL Server 2000的...

    一个SqlServer触发器的Delphi应用源代码..rar

    本资源“一个SqlServer触发器的Delphi应用源代码..rar”显然是一个结合了这两个技术的实例,旨在帮助开发者了解如何在Delphi中使用SQL Server触发器。 触发器是SQL Server中的一个重要特性,它是一种存储过程,由...

    sql server2000完整教程

    学习T-SQL的基本语法,如SELECT、INSERT、UPDATE、DELETE语句,以及存储过程、触发器等高级特性,是掌握SQL Server 2000的关键。 六、视图与游标 视图是虚拟表,基于一个或多个表的查询结果。游标则允许逐行处理...

    SQL Server 2000数据库教程(华夏学院)

    SQL Server 2000概述、SQL Server 2000安装和配置、SQL Server 2000工具、数据库系统基础、SQL Server 2000数据类型...触发器、存储过程、SQL Server 2000数据库的安全性管理、数据库的备份和恢复、基于Web的数据库应用...

    SQL server存储过程习题,SQL触发器习题.rar

    在SQL Server数据库管理系统中,存储过程和触发器是两种非常重要的数据库编程元素,它们对于数据库设计和数据管理具有深远的影响。下面将详细讲解这两个概念及其相关的知识点。 **SQL存储过程**: 1. **定义**:SQL...

Global site tag (gtag.js) - Google Analytics