知识大全 SQL Server触发器创建、删除、修改、查看

Posted 语句

篇首语:与有肝胆人共事,从无字句处读书。本文由小常识网(cha138.com)小编为大家整理,主要介绍了知识大全 SQL Server触发器创建、删除、修改、查看相关的知识,希望对你有一定的参考价值。

SQL Server触发器创建、删除、修改、查看  以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!

  一 触发器是一种特殊的存储过程 它不能被显式地调用 而是在往表中插入记录﹑更新记录或者删除记录时被自动地激活 所以触发器可以用来实现对表实施复杂的完整性约束

  二 SQL Server为每个触发器都创建了两个专用表 Inserted表和Deleted表 这两个表由系统来维护 它们存在于内存中而不是在数据库中 这两个表的结构总是与被该触发器作用的表的结构相同 触发器执行 完成后 与该触发器相关的这两个表也被删除

  Deleted表存放由于执行Delete或Update语句而要从表中删除的所有行

  Inserted表存放由于执行Insert或Update语句而要向表中插入的所有行

  三 Instead of 和 After触发器

  SQL Server 提供了两种触发器 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 jxcSofare

  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

  九 相关示例

  在Orders表中建立触发器 当向Orders表中插入一条订单记录时 检查goods表的货品状态status是否为 (正在整理) 是 则不能往Orders表加入该订单

  create trigger orderinsert

  on orders

  after insert

  as

  if (select status from goods inserted

  where goods name=inserted goodsname)=

  begin

  print the goods is being processed

  print the order cannot be mitted

  rollback transaction 回滚 避免加入

  end

  在Orders表建立一个插入触发器 在添加一条订单时 减少Goods表相应的货品记录中的库存

  create trigger orderinsert

  on orders

  after insert

  as

  update goods set storage=storage inserted quantity

  from goods inserted

  where

  goods name=inserted goodsname

  在Goods表建立删除触发器 实现Goods表和Orders表的级联删除

  create trigger goodsdelete

  on goods

  after delete

  as

  delete from orders

  where goodsname in

  (select name from deleted)

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

  create trigger orderdateupdate

  on orders

  after update

  as

  if update(orderdate)

  begin

  raiserror( orderdate cannot be modified )

  rollback transaction

  end

  在Orders表建立一个插入触发器 保证向Orders表插入的货品名必须要在Goods表中一定存在

  create trigger orderinsert

  on orders

  after insert

  as

  if (select count(*) from goods inserted where goods name=inserted goodsname)=

  begin

  print no entry in goods for this order

  rollback transaction

  end

  Orders表建立一个插入触发器 保证向Orders表插入的货品信息要在Order表中添加

  alter trigger addOrder

  on Orders

  for insert

  as

  insert into Order

cha138/Article/program/SQLServer/201311/22002

相关参考

知识大全 用户信息的查看、修改和删除[1]

    ——此文章摘自《ASPNET+SQLServer网络应用系统开发案例精解》定价¥ 特价¥详细>>//tracklinktechcn/?m_i

知识大全 用户信息的查看、修改和删除[3]

    ——此文章摘自《ASPNET+SQLServer网络应用系统开发案例精解》定价¥ 特价¥详细>>//tracklinktechcn/?m_i

知识大全 用户信息的查看、修改和删除[4]

    ——此文章摘自《ASPNET+SQLServer网络应用系统开发案例精解》定价¥ 特价¥详细>>//tracklinktechcn/?m_i

知识大全 用户信息的查看、修改和删除[5]

    ——此文章摘自《ASPNET+SQLServer网络应用系统开发案例精解》定价¥ 特价¥详细>>   &nbs

知识大全 在SQL Server中快速删除重复记录

在SQLServer中快速删除重复记录  以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!lishixi

知识大全 使用FORFILES命令来删除SQL Server备份

使用FORFILES命令来删除SQLServer备份  以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!

知识大全 在SQL Server中如何删除数据库

在SQLServer中如何删除数据库  以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!lishixin

知识大全 使用 SQL Server创建语言辅助函数

使用SQLServer创建语言辅助函数  以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!  在现在这样

知识大全 sql server如何识别真实和自动创建的索引

  问我发现sysindexes索引表中的很多条目并不是我自己创建的听说它们并不是真正的索引而是SQLServer查询优化器自动创建的统计怎样才能识别哪些是真正的索引哪些是SQLServer自动创建的

知识大全 关于修改SQL Server表的结构的问答

关于修改SQLServer表的结构的问答  以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!  Qjpl