SQL中,触发器是什么?
1个回答
展开全部
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
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询