`
baobeituping
  • 浏览: 1041259 次
  • 性别: 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
分享到:
评论

相关推荐

    SQLserver08触发器

    适合开始学习写sql 触发器的同学;一看就会,好好看吧!!

    SQLServer-触发器使用实例.docx

    SQLServer-触发器使用实例.docx

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

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

    用sql脚本创建sqlserver数据库触发器范例语句

    创建SqlServer数据库触发器脚本范例,方便大家用sql来创建触发器,学习sqlserver的朋友可以参考下。

    SQL Server 2008完全学习手册视频教程.zip

    第1章 SQL Server 2008入门知识 SQL 2008完全学习手册 视频教程 第2章 使用SQL Server 2008管理工具 SQL 2008完全学习手册 视频教程 第3章 管理数据库 SQL 2008完全学习手册 视频教程 第4章 SQL Server 2008数据表...

    sqlserver 禁用触发器和启用触发器的语句

    您可能感兴趣的文章:SQLServer2005触发器提示其他会话正在使用事务的上下文的解决方法SQL Server触发器及触发器中的事务学习SQL Server 触发器 表的特定字段更新时,触发Update触发器SQLServer触发器创建、删除、...

    sql server 2005学习笔记之触发器

    sql server 2005学习笔记之触发器 很全 说的很详细

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

    总结常用基本点如下: 1、触发器有两种类型:数据定义语言触发器(DDL触发器)和数据操纵语言触发器(DML触发器)。 DDL触发器:在用户对数据库执行数据定义(CREATE、ALTER、DROP或相似的语句)对数据库结构进行...

    SQL Server 2000数据库及应用 学习资料

    SQL Server 2000数据库及应用 学习资料 含1关系数据库与SQL Server 2000概述 2第二章创建和管理数据库 3第三章数据库设计 基础 4表 5Transact-SQL语言 6视图 7索引 8其它数据库对象 9存储过程 10触发器 里面含有...

    SQLServer2005数据库学习笔记

    笔记是本人学习SQLServer一段时间后重新整理出来的,适合有一些入门基础的人学习。 ├─01 安装及使用 │ SQLServer2005安装及使用.txt │ ├─02 常用函数 │ function.sql │ ├─03 建表、建库 │ create.sql ...

    sql server触发器工作原理

    sql server触发器工作原理 京华志&精华志出品 希望大家互相学习,互相进步 支持CSDN 支持微软 主要包括C# ASP.NET SQLDBA 源码 毕业设计 开题报告 答辩PPT等等好多知识

    SQL Server数据库入门学习总结

    数据库是如何显示数据的 select SQLServer数据库学习总结 1.SQL基础 SQL Server2000安装、配置,服务器启动、停止,企业管理器、查询分析器 第一代数据库–网状数据库和层次数据库;第二代数据库–关系数

    SQL Server触发器及触发器中的事务学习

    如果你有对触发器和事务的概念,有些了解,这篇文章,对你来说会是很简单,或能让你更进一步的了解触发器里面的一些故事,和... 在下面的内容,用到一些SQL Server 触发器和事务的一些术语,如果有些不明白的地方,

    Navicat for SQL Server(SQLServer数据库管理)V11.0.10简体中文特别版

    它可以用于 SQL Server 2000、2005 及 2008R2,并支持大部份最新功能,包括触发器、函数及其他。Navicat 的功能足以符合专业开发人员的所有需求,但是对 SQL Server 的新手来说又相当容易学习。 有了 Navicat 极完备...

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

    SQL存储过程习题,SQL触发器习题,SQL习题,基础语法,与W3School类似,初学者学习使用。

    SQL Server 2008宝典

    第2部分为SQLServer 2008的准备篇,介绍了SQL Server 2008的功能、特性、各版本的比较、安装方法、SQL Server 2008的服务、客户端的工具等;第3部分为SQL Server 2008的基本操作篇,介绍如何管理与配置SQL Server ...

    节SQL Server存储过程和触发器PPT学习教案.pptx

    节SQL Server存储过程和触发器PPT学习教案.pptx

Global site tag (gtag.js) - Google Analytics