触发器的作用:
自动计算数据值,如果数据的值达到了一定的要求,则进行特定的处理。
同步实时地复制表中的数据。
实现复杂的非标准的数据库相关完整性规则。
可在写入数据表前,强制检验或转换数据。
触发器发生错误时,异动的结果会被撤销。
部分数据库管理系统可以针对数据定义语言(DDL)使用触发器,称为DDL触发器。
可依照特定的情况,替换异动的指令 (INSTEAD OF)。
扩展资料:
分类
SQL Server 包括三种常规类型的触发器:DML 触发器、DDL 触发器和登录触发器。
DML触发器
当数据库中表中的数据发生变化时,包括insert,update,delete任意 *** 作,如果我们对该表写了对应的DML触发器,那么该触发器自动执行。
DML触发器的主要作用在于强制执行业 务规则,以及扩展Sql Server约束,默认值等。因为我们知道约束只能约束同一个表中的数据,而触发器中则可以执行任意Sql命令。
DDL触发器
它是Sql Server2005新增的触发器,主要用于审核与规范对数据库中表,触发器,视图等结构上的 *** 作。比如在修改表,修改列,新增表,新增列等。
它在数据库结构发生变化时执行,我们主要用它来记录数据库的修改过程,以及限制程序员对数据库的修改,比如不允许删除某些指定表等。
登录触发器
登录触发器将为响应 LOGIN 事件而激发存储过程。与 SQL Server 实例建立用户会话时将引发此事件。登录触发器将在登录的身份验证阶段完成之后且用户会话实际建立之前激发。
因此,来自触发器内部且通常将到达用户的所有消息(例如错误消息和来自 PRINT 语句的消息)会传送到 SQL Server 错误日志。如果身份验证失败,将不激发登录触发器。
参考资料来源:百度百科-触发器
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欢迎分享,转载请注明来源:内存溢出
评论列表(0条)