触发器(Trigger)(四)

转载 2007年09月20日 08:58:00

设计After触发器

在了解触发器及其种类、作用、工作原理之后,下面详细讲述一下要怎么去设计及建立触发器。

 设计简单的After触发器

下面用实例设计一个简单的After Insert触发器,这个触发器的作用是:在插入一条记录的时候,发出又添加了一种产品的友好提示。

1)启动Management Studio,登录到指定的服务器上。

2)在如图1所示界面的【对象资源管理器】下选择【数据库】,定位到【Northwind】数据库à【表】àdbo.产品】,并找到【触发器】项。

1 定位到触发器

3)右击【触发器】,在弹出的快捷菜单中选择【新建触发器】选项,此时会自动弹出【查询编辑器】对话框,在【查询编辑器】的编辑区里SQL Server已经预写入了一些建立触发器相关的SQL语句,如图11.2所示。

2 SQL Server 2005预写的触发器代码

4)修改【查询编辑器】里的代码,将从“CREATE”开始到“GO”结束的代码改为以下代码:

CREATE TRIGGER 产品_Insert

   ON  产品

   AFTER INSERT

AS

BEGIN

         print '又添加了一种产品'

END

GO

如果有兴趣的话,也可以去修改一下如图11.2中绿色部分的版权信息。

5)单击工具栏中的【分析】按钮,检查一下是否语法有错,如图11.3所示,如果在下面的【结果】对话框中出现命令已成功完成,则表示语法没有错误。

3 检查语法

6)语法检查无误后,单击【执行】按钮,生成触发器。

7)关掉查询编辑器对话框,刷新一下触发器对话框,可以看到刚才建立的【产品_Insert】触发器,如图4所示。

4 建好的触发器

建立After Update触发器、After Delete触发器和建立After Insert触发器的步骤一致,不同的地方是把上面的SQL语句中的AFTER INSERT分别改为AFTER UPDATEAFTER DELETE即可,如下所示,有兴趣的读者可以自行测试。

CREATE TRIGGER 产品_Update

   ON  产品

   AFTER UPDATE

AS

BEGIN

         print '有一种产品更改了'

END

GO

CREATE TRIGGER 产品_Delete

   ON  产品

   AFTER DELETE

AS

BEGIN

         print '又删除了一种产品'

END

GO

  测试触发器功能

建好After Insert触发器之后,现在来测试一下触发器是怎么样被激活的。

1)在Management Studio里新建一个查询,在弹出的【查询编辑器】对话框里输入以下代码:

INSERT INTO 产品(产品名称) VALUES ('大苹果')

2)单击【执行】按钮,可以看到【消息】对话框里显示出一句提示:又添加了一种产品,如图11.5所示,这说明,After Insert触发器被激活,并运行成功了。

5 查看触发器的运行结果

而如果在【查询编辑器】里执行的不是一个Insert语句,而是一个Delete语句的话,After Insert触发器将不会被激活。如在【查询编辑器】输入以下语句:

DELETE FROM 产品 WHERE (产品名称= '大苹果')

单击【执行】按钮,在【消息】对话框里只显示了一句“(1行受影响)”的提示,而没有又添加了一种产品的提示,如图6所示。这是因为Delete语句是不能激活After Insert触发器,所以After Insert触发器里的“print ‘又添加了一种产品’”语句并没有执行。

6 执行删除语句不会激活After Insert触发器

 

trigger触发器和自定义方法

$(function () { var oTxt = $("input"); //trigger触发器,需要把事件放在自己的身上去触发事件;触发事件不需要用户...
  • younghaiqing
  • younghaiqing
  • 2016年10月21日 15:35
  • 706

[oracle] 触发器使用教程和命名规范

触发器使用教程和命名规范       目  录   触发器使用教程和命名规范    1  1,触发器简介 1  2,触发器示例 2  3,触发器语法和功能  3  4,例一:行级触发器之一    4 ...
  • xys_777
  • xys_777
  • 2010年07月16日 01:04
  • 4306

Sybase触发器学习

这几日需要设计项目的几个报表统计模块,然后统计其数值。时间甚赶,需要新增一堆表,且以前的一个主表被修改并没有对应的log表,得重新设计。写log表要求使用触发器实现。   所以在网上查找半天syba...
  • qq_29663071
  • qq_29663071
  • 2016年07月15日 13:45
  • 271

android:SQLite--触发器详解

关于SQLite基础部分:SQLite基础学习 SQLite 的触发器是数据库的回调函数,它会自动执行/指定的数据库事件发生时调用。SQLite 的触发器可以指定在特定的数据库表发生 delet...
  • qq_17326933
  • qq_17326933
  • 2015年09月01日 21:24
  • 3325

oracle数据库触发器(trigger)用法总结

http://yedward.net/?id=116   触发器的意思就是当我们对数据库对象(一般是表或视图)进行insert、update、delete操作的时候,这些操作会相应的触发一些事件的...
  • zhanzhib
  • zhanzhib
  • 2015年09月25日 10:12
  • 10626

数据库(SQL)之trigger(触发器)的使用以及视图(view)的基本实现

对于触发器,首先需要明确的是一下几点: trigger_name 必须给触发器命令,最多64个字符,建议用表的名字_触发器类型的缩写方法命名。如ttlsa_posts_bi(表ttlsa_posts,...
  • u013816144
  • u013816144
  • 2015年12月05日 12:18
  • 1236

SQLite创建触发器 CREATE TRIGGER

CREATE TRIGGER sql-statement ::=CREATE[TEMP|TEMPORARY]TRIGGERtrigger-name[BEFORE|AFTER] database-ev...
  • L_serein
  • L_serein
  • 2012年11月09日 15:42
  • 4811

Oracle Trigger 触发器

Oracle Trigger 在Oracle8i之前,只允许给予表或者视图的的DML的操作,而从Oracle8i开始,不仅可以支持DML触发器,也允许给予系统事件和DDL的操作. 一、触发器的分类...
  • bbliutao
  • bbliutao
  • 2012年08月06日 11:16
  • 1878

MySQL触发器Trigger实例篇

MySQL触发器Trigger实例篇 发表于668 天前 ⁄ IT技术 ⁄ 暂无评论 以前关注的数据存储过程不太懂其中奥妙,最近遇到跨数据库,同时对多个表进行CURD(Create...
  • hireboy
  • hireboy
  • 2014年01月10日 11:45
  • 29256

sqlite3触发器的使用

研究了一下osx下dock中应用的存储,位于~/Library/Application Support/Dock/下一个比较名字比较长的db文件中,之前简单的介绍过osx launchpad图标的删除...
  • dliyuedong
  • dliyuedong
  • 2014年10月29日 00:22
  • 10376
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:触发器(Trigger)(四)
举报原因:
原因补充:

(最多只允许输入30个字)