All articles| All Pictures| All Softwares| All Video| Go home page| Write articles| Upload pictures

Reading number is top 10 articles
讲解MySQL数据库与ASP.NET如何强强联手_.net资料_编程技术
变量的变量,PHP,和,你_php资料_编程技术
用gridview显示来自excel表格里的数据_[Asp.Net教程]
Ajax核心:XMLHTTP组件相关技术资料_[AJAX教程]
PHP实例程序:用PHP制作登录页面程序_php资料_编程技术
轻松掌握Ajax.net系列教程六:使用PopupControlExtender_[Asp.Net教程]
C#,IDataReader造成的资源泄漏_.net资料_编程技术
asp.net教程-返回前一页实现方法总结_[Asp.Net教程]
用PHP与XML联手进行网站编程理论分析_php资料_编程技术
WML Script标准函数库_[XML教程]
Reading number is top 10 pictures
The real super beauty13
HongMenYan premiere XinLiangGong clairvoyant outfit PK YiFeiLiu2
湖边的风景
A man's favorite things12
2012 national geographic daily picture4
Summer is most suitable for young people to travel in China8
So beauty, will let you spray blood4
你的钱干净吗?
贩卖儿童者必须判死刑
Sora aoi mirror memorial classics4
Download software ranking
传奇私服架设教程-chm
Jinling thirteen stock
Take off clothes to survival
Detective task-the top secret prostitution files
致我们终将逝去的青春
尖东毒玫瑰B
Boxer Classic video3
White deer villiage
Tram sex maniac 2 (H) rar bag17
实战黑客不求人
归海一刀 published in(发表于) 2014/2/1 0:14:43 Edit(编辑)
SqlServer数据库触发器实例讲解_[SQL,Server教程]

SqlServer数据库触发器实例讲解_[SQL,Server教程]

SqlServer数据库触发器实例讲解_[SQL Server教程]


定义: 何为触发器?在SQL Server里面也就是对某一个表的一定的操作,触发某种条件,从而执行的一段程序。触发器是一个特殊的存储过程。


常见的触发器有三种:分别应用于Insert , Update , Delete 事件。(SQL Server 2000定义了新的触发器,这里不提)


我为什么要使用触发器?比如,这么两个表:


用到的功能有:1.如果我更改了学生的学号,我希望他的借书记录仍然与这个学生相关(也就是同时更改借书记录表的学号);2.如果该学生已经毕业,我希望删除他的学号的同时,也删除它的借书记录,等等。


这时候可以用到触发器。对于1,创建一个Update触发器:



Create Trigger truStudent
On Student--在Student表中创建触发器 for Update--为什么事件触发As--事件触发后所要做的事情
if Update(StudentID) begin



Update BorrowRecordSet StudentID=i.StudentIDFrom BorrowRecord br , Deletedd ,
Inserted i--Deleted和Inserted临时表Where br.StudentID=d.StudentID



end


理解触发器里面的两个临时的表:Deleted , Inserted 。注意Deleted 与Inserted分别表示触发事件的表“旧的一条记录”和“新的一条记录”。


一个数据库系统中有两个虚拟表用于存储在表中记录改动的信息,分别是:


虚拟表Inserted虚拟表Deleted


在表记录新增时存放新增的记录不存储记录
修改时存放用来更新的新记录 存放更新前的记录
删除时不存储记录 存放被删除的记录


一个Update 的过程可以看作为:生成新的记录到Inserted表,复制旧的记录到Deleted表,然后删除Student记录并写入新纪录。


对于2,创建一个Delete触发器


Create trigger trdStudent On Student for DeleteAs Delete BorrowRecord From BorrowRecord br ,
Delted d Where br.StudentID=d.StudentID


从这两个例子我们可以看到了触发器的关键:A.2个临时的表;B.触发机制。

这里我们只讲解最简单的触发器。复杂的容后说明。
事实上,我不鼓励使用触发器。触发器的初始设计思想,已经被“级联”所替代。

来源:网络







添加到del.icio.us 添加到新浪ViVi 添加到百度搜藏 添加到POCO网摘 添加到天天网摘365Key 添加到和讯网摘 添加到天极网摘 添加到黑米书签 添加到QQ书签 添加到雅虎收藏 添加到奇客发现 diigo it 添加到饭否 添加到飞豆订阅 添加到抓虾收藏 添加到鲜果订阅 digg it 貼到funP 添加到有道阅读 Live Favorites 添加到Newsvine 打印本页 用Email发送本页 在Facebook上分享


Disclaimer Privacy Policy About us Site Map

If you have any requirements, please contact webmaster。(如果有什么要求,请联系站长)
Copyright ©2011-
uuhomepage.com, Inc. All rights reserved.