问答文章1 问答文章501 问答文章1001 问答文章1501 问答文章2001 问答文章2501 问答文章3001 问答文章3501 问答文章4001 问答文章4501 问答文章5001 问答文章5501 问答文章6001 问答文章6501 问答文章7001 问答文章7501 问答文章8001 问答文章8501 问答文章9001 问答文章9501

SQL中,触发器是什么?

发布网友 发布时间:2023-11-08 20:43

我来回答

1个回答

热心网友 时间:2024-12-04 06:41

1. 基本概念\x0d\x0a触发器是特殊的存储过程,基于一个表创建,主要作用就是实现由主键和外键所不能保证的复杂的参照完整性和数据一致性。\x0d\x0a当触发器所保护的数据发生变化(update,insert,delete)后,自动运行以保证数据的完整性和正确性。通俗的说:通过一个动作(update,insert,delete)调用一个存储过程(触发器)。\x0d\x0a2. 类型\x0d\x0a(1)DML触发器\x0d\x0a在数据库中发生数据操作语言(DML)事件时将启用。DML 事件包括在指定表或视图中修改数据的 INSERT 语句、UPDATE 语句或 DELETE 语句。DML 触发器可以查询其他表,还可以包含复杂的 T-SQL 语句。系统将触发器和触发它的语句作为可在触发器内回滚的单个事务对待,如果检测到错误(例如,磁盘空间不足),则整个事务即自动回滚。\x0d\x0a(2)DDL 触发器\x0d\x0aSQL Server 2005 的新增功能。当服务器或数据库中发生数据定义语言(DDL)事件时将调用这些触发器。但与DML触发器不同的是,它们不会为响应针对表或视图的UPDATE、INSERT或DELETE语句而激发,相反,它们会为响应多种数据定义语言(DDL)语句而激发。这些语句主要是以CREATE、ALTER和DROP开头的语句。DDL触发器可用于管理任务,例如审核和控制数据库操作。\x0d\x0a 创建DML触发器\x0d\x0a1. 使用存储过程模板创建存储过程\x0d\x0a在【对象资源管理器】窗口中,展开“数据库”节点,再展开所选择的具体数据库节点,再展开“表”节点,右击要创建触发器的“表”,选择“新建触发器”命令,如图所示:\x0d\x0a在右侧查询编辑器中出现触发器设计模板,用户可以在此基础上编辑触发器,单击“执行”按钮,即可创建该触发器。\x0d\x0a\x0d\x0a2. 使用T-SQL语句创建表\x0d\x0aCREATE TRIGGER 触发器\x0d\x0aON 表名\x0d\x0aFOR[update,insert,delete ]\x0d\x0aAS SQL语句\x0d\x0a例9-6:创建基于表reader ,DELETE操作的触发器。\x0d\x0aUSE Library\x0d\x0aGO\x0d\x0aIF EXISTS(SELECT name FROM sysobjects\x0d\x0a WHERE name='reader_d' AND type='TR')\x0d\x0aDROP TRIGGER reader_d --如果已经存在触发器reader_d则删除\x0d\x0aGO\x0d\x0aCREATE TRIGGER reader_d --创建触发器\x0d\x0aON reader --基于表 \x0d\x0aFOR DELETE --删除事件\x0d\x0aAS\x0d\x0aPRINT '数据被删除!' --执行显示输出\x0d\x0aGO\x0d\x0a 试试吧!\x0d\x0a应用:\x0d\x0aUSE Library\x0d\x0aGO\x0d\x0aDELETE reader\x0d\x0awhere Rname='aaa'\x0d\x0a执行结果:\x0d\x0a数据被删除!\x0d\x0a(所影响的行数为 1 行)\x0d\x0a例9-7:在表borrow中添加借阅信息记录时,得到该书的应还日期。\x0d\x0a说明:在表borrow中增加一个应还日期SReturnDate。\x0d\x0aUSE Library\x0d\x0aIF EXISTS (SELECT name FROM sysobjects\x0d\x0aWHERE name ='T_return_date' AND type='TR')\x0d\x0aDROP TRIGGER T_return_date\x0d\x0aGO\x0d\x0aCREATE TRIGGER T_return_date --创建触发器\x0d\x0aON Borrow --基于表borrow\x0d\x0aAfter INSERT --插入操作\x0d\x0aAS\x0d\x0a--查询插入记录INSERTED中读者的类型\x0d\x0aDECLARE @type int,@dzbh char(10),@tsbh char(15)\x0d\x0aSET @dzbh=(SELECT RID FROM inserted)\x0d\x0aSET @tsbh=(SELECT BID FROM inserted)\x0d\x0aSELECT @type= TypeID\x0d\x0aFROM reader\x0d\x0aWHERE RID=(SELECT RID FROM inserted)--副本\x0d\x0a/*把Borrow表中的应还日期改为\x0d\x0a当前日期加上各类读者的借阅期限*/\x0d\x0aUPDATE Borrow SET SReturnDate=getdate()+\x0d\x0aCASE \x0d\x0a WHEN @type=1 THEN 90\x0d\x0a WHEN @type=2 THEN 60\x0d\x0a WHEN @type=3 THEN 30\x0d\x0aEND\x0d\x0aWHERE RID=@dzbh and BID=@tsbh\x0d\x0a应用:\x0d\x0aUSE Library\x0d\x0aINSERT INTO borrow(RID,BID) values('2000186010','TP85-08')\x0d\x0a查看记录:\x0d\x0a \x0d\x0a例9-8:在数据库Library中,当读者还书时,实际上要修改表brorrowinf中相应记录还期列的值,请计算出是否过期。\x0d\x0aUSE Library\x0d\x0aIF EXISTS(SELECT name FROM sysobjects\x0d\x0aWHERE name='T_fine_js' AND type='TR')\x0d\x0aDROP TRIGGER T_fine_js\x0d\x0aGO\x0d\x0aCREATE TRIGGER T_fine_js\x0d\x0aON borrow\x0d\x0aAfter UPDATE\x0d\x0aAS\x0d\x0aDECLARE @days int,@dzbh char(10),@tsbh char(15)\x0d\x0aSET @dzbh=(select RID from inserted)\x0d\x0aSET @tsbh=(select BID from inserted)\x0d\x0aSELECT @days=DATEDIFF(day, ReturnDate, SReturnDate)\x0d\x0a--DATEDIFF函数返回两个日期之差,单位为DAY\x0d\x0aFROM borrow\x0d\x0aWHERE RID=@dzbh and BID=@tsbh\x0d\x0aIF @days>0\x0d\x0a PRINT '没有过期!'\x0d\x0aELSE\x0d\x0a PRINT '过期'+convert(char(6),@days)+'天'\x0d\x0aGO\x0d\x0a应用:\x0d\x0aUSE Library\x0d\x0aUPDATE borrow SET ReturnDate='2007-12-12'\x0d\x0aWHERE RID='2000186010' and BID='TP85-08'\x0d\x0aGO\x0d\x0a执行结果:\x0d\x0a过期-157 天\x0d\x0a(1 行受影响)\x0d\x0a例9-9:对Library库中Reader表的 DELETE操作定义触发器。\x0d\x0aUSE Library\x0d\x0aGO\x0d\x0aIF EXISTS(SELECT name FROM sysobjects\x0d\x0a WHERE name='reader_d' AND type='TR')\x0d\x0aDROP TRIGGER reader_d\x0d\x0aGO\x0d\x0aCREATE TRIGGER reader_d\x0d\x0aON Reader\x0d\x0aFOR DELETE\x0d\x0aAS\x0d\x0aDECLARE @data_yj int\x0d\x0aSELECT @data_yj=Lendnum\x0d\x0aFROM deleted\x0d\x0aIF @data_yj>0\x0d\x0a BEGIN\x0d\x0a PRINT '该读者不能删除!还有'+convert(char(2),@data_yj)+'本书没还。\x0d\x0a ROLLBACK\x0d\x0a END\x0d\x0aELSE\x0d\x0a PRINT '该读者已被删除!'\x0d\x0aGO\x0d\x0a应用:\x0d\x0aUSE Library\x0d\x0aGO\x0d\x0aDELETE Reader WHERE RID='2005216119'\x0d\x0a执行结果:\x0d\x0a该读者不能删除!还有4 本书没还。\x0d\x0a 修改触发器\x0d\x0aALTER TRIGGER 触发器\x0d\x0a 删除触发器\x0d\x0aDROP TRIGGER 触发器\x0d\x0a 查看触发器\x0d\x0asp_helptext trigger_name\x0d\x0asp_helptrigger table_name
声明声明:本网页内容为用户发布,旨在传播知识,不代表本网认同其观点,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。E-MAIL:11247931@qq.com
空调加氟时要注意什么? 电脑安装了pr兼容性pr显示系统兼容性报告 带你了解——赫伯罗特 一千克面粉三十元一克面粉多少钱 大米2元500克面粉3元500克 2千克大米和和1500克面粉多少钱?_百度... ...面粉每千克多少元.大米25千克4.5元一千克面粉2 买8000克面粉需要32元,每千克面粉多少钱 500克面粉2元钱1千克面粉多少钱,怎么练式? 软棕和硬棕哪个好 amd rx6800m相当于nvidia什么水平? “保护美丽河湖,建设美好家园”书信500字922 保护美丽河湖,建设美好家园的作文用书信格式写,六年级500字2 上海百岁老人长寿秘诀是养生,养生真的能够让人长寿吗? 2021江苏省南京市高淳区部分机关单位招聘编外人员公告【60人】_百度... 欧豹TD1000.欧豹FT1000.欧豹N1000D型拖拉机...9 爱的教育士兵读后感300字以上5 红楼梦中贾宝玉给你留下了怎样的印象只限七十字?24 爱的教育之夜校读后感300字4 wish和hope的区别用法1140 山东星一进出口集团有限公司怎么样?5 北京公寓有哪些?在什么地点?3 会出现系统更新进度条,但到90%就卡住了什么弄 大连老虎滩好玩吗?76 大连圣亚和老虎滩哪个好玩吗?1615 用吸奶器喂宝宝一直喂宝宝会有什么影响吗 李歆的凤栖梧22 李歆<凤栖梧>的结局是怎样的?10 pi币邀请人能随便拉黑下线吗 收到PiKYC认证邀请了必须要24小时之内认证吗?如果错过了时间没有认证... 卧室适合放什么样的沙发? i9308提示系统更新,点安装后重启,每次进度到25%的时候... 给女朋友取什么外号叫女朋友才会喜欢1 手机是双卡双待的,一个电信一个移动,能不能申请两个用,14 在美国买面膜,什么牌子的好?价钱多少?4 河北区语文六年级第二学期复习题53 花生仁和瓜子仁哪个出油率高?2 钻戒上刻有pt950do85ct是什么意思2 冰糖麻饼的热量是多少啊?里面包有花生、芝麻、瓜子仁、还有冰糖... 同望公路如何建立多个单价或费率文件及其用途?4 简述客房产品的内涵和特点3 简述客房产品的特点25 魔兽世界大灾变猎人的天赋和输出手法 否定重复什么意思?2 美国为什么不推翻古巴 长春有几个开发区?3 举办一次COS需要的经费有哪些方面7 天津有哪几个开发区?10 如何在两部手机同时登陆一个?1 有cos团体愿意免费演出吗?2 过几天去大连我想问一下 大连的老虎滩和金石滩有什么不同 哪个...13