1.安全性。能够基于数据库的值使用户具有 *** 作数据库的某种权利。
# 能够基于时间限制用户的 *** 作,比如不同意下班后和节假日改动数据库数据。
2.审计。能够跟踪用户对数据库的 *** 作。
# 审计用户 *** 作数据库的语句。
# 把用户对数据库的更新写入审计表。
3.实现复杂的数据完整性规则
# 实现非标准的数据完整性检查和约束。触发器可产生比规则更为复杂的限制。与规则不同,触发器能够引用列或数据库对象。比如,触发器可回退不论什么企图吃进超过自己保证金的期货。
# 提供可变的缺省值。
4.实现复杂的非标准的数据库相关完整性规则。触发器能够对数据库中相关的表进行连环更新。比如,在auths表author_code列上的删除触发器可导致对应删除在其他表中的与之匹配的行。
# 在改动或删除时级联改动或删除其他表中的与之匹配的行。
# 在改动或删除时把其他表中的与之匹配的行设成NULL值。
# 在改动或删除时把其他表中的与之匹配的行级联设成缺省值。
# 触发器可以拒绝或回退那些破坏相关完整性的变化,取消试图进行数据更新的事务。当插入一个与其主健不匹配的外部键时,这样的触发器会起作用。比如,可以在books.author_code 列上生成一个插入触发器,假设新值与auths.author_code列中的某值不匹配时,插入被回退。
5.同步实时地复制表中的数据。
6.自己主动计算数据值,假设数据的值达到了一定的要求,则进行特定的处理
触发器(trigger)是SQL server 提供给程序员和数据分析员来保证数据完整性的一种方法,它是与表事件相关的特殊的存储过程,它的执行不是由程序调用,也不是手工启动,而是由事件来触发,比如当对一个表进行 *** 作( insert,delete, update)时就会激活它执行。触发器经常用于加强数据的完整性约束和业务规则等。 触发器可以从 DBA_TRIGGERS ,USER_TRIGGERS 数据字典中查到。SQL3的触发器是一个能由系统自动执行对数据库修改的语句。\x0d\x0a触发器与存储过程的唯一区别是触发器不能执行EXECUTE语句调用,而是在用户执行Transact-SQL语句时自动触发执行。\x0d\x0a触发器可以查询其他表,而且可以包含复杂的SQL语句。它们主要用于强制服从复杂的业务规则或要求。例如:您可以根据客户当前的帐户状态,控制是否允许插入新订单。\x0d\x0a触发器也可用于强制引用完整性,以便在多个表中添加、更新或删除行时,保留在这些表之间所定义的关系。然而,强制引用完整性的最好方法是在相关表中定义主键和外键约束。如果使用数据库关系图,则可以在表之间创建关系以自动创建外键约束。\x0d\x0aSQL Server 包括三种常规类型的触发器:DML 触发器、DDL 触发器和登录触发器。\x0d\x0a语法为:\x0d\x0aCREATE TRIGGER ``.``\x0d\x0a \x0d\x0aON [dbo] //dbo代表该表的所有者\x0d\x0aFOR EACH ROW\x0d\x0aBEGIN\x0d\x0a --do something\x0d\x0aEND\x0d\x0a 触发器可通过数据库中的相关表实现级联更改,不过,通过级联引用完整性约束可以更有效地执行这些更改。触发器可以强制比用CHECK约束定义的约束更为复杂的约束。与 CHECK 约束不同,触发器可以引用其它表中的列。例如,触发器可以使用另一个表中的 SELECT 比较插入或更新的数据,以及执行其它 *** 作,如修改数据或显示用户定义错误信息。触发器也可以评估数据修改前后的表状态,并根据其差异采取对策。一个表中的多个同类触发器(INSERT、UPDATE 或 DELETE)允许采取多个不同的对策以响应同一个修改语句。\x0d\x0a约束和触发器在特殊情况下各有优势。触发器的主要好处在于它们可以包含使用 Transact-SQL 代码的复杂处理逻辑。因此,触发器可以支持约束的所有功能;但它在所给出的功能上并不总是最好的方法。实体完整性总应在最低级别上通过索引进行强制,这些索引或是 PRIMARY KEY 和 UNIQUE 约束的一部分,或是在约束之外独立创建的。假设功能可以满足应用程序的功能需求,域完整性应通过 CHECK 约束进行强制,而引用完整性(RI) 则应通过 FOREIGN KEY 约束进行强制。在约束所支持的功能无法满足应用程序的功能要求时,触发器就极为有用。\x0d\x0aCHECK 约束只能根据逻辑表达式或同一表中的另一列来验证列值。如果应用程序要求根据另一个表中的列验证列值,则必须使用触发器。约束只能通过标准的系统错误信息传递错误信息。如果应用程序要求使用(或能从中获益)自定义信息和较为复杂的错误处理,则必须使用触发器。\x0d\x0a 触发器可通过数据库中的相关表实现级联更改;不过,通过级联引用完整性约束可以更有效地执行这些更改。触发器可以禁止或回滚违反引用完整性的更改,从而取消所尝试的数据修改。当更改外键且新值与主键不匹配时,此类触发器就可能发生作用。例如,可以在 titleauthor.title_id 上创建一个插入触发器,使它在新值与 titles.title_id 中的某个值不匹配时回滚一个插入。不过,通常使用 FOREIGN KEY 来达到这个目的。\x0d\x0a 如果触发器表上存在约束,则在 INSTEAD OF 触发器执行后但在 AFTER 触发器执行前检查这些约束。如果约束破坏,则回滚 INSTEAD OF 触发器 *** 作并且不执行 AFTER 触发器。\x0d\x0a实例1:insert触发器\x0d\x0acreate trigger tri_insert\x0d\x0aon student\x0d\x0afor insert\x0d\x0aas\x0d\x0adeclare @student_id char(10)\x0d\x0aselect @student_id=s.student_id from\x0d\x0astudent s inner join inserted i\x0d\x0aon s.student_id=i.student_id\x0d\x0aif @student_id='0000000001'\x0d\x0abegin\x0d\x0araiserror('不能插入1的学号!',16,8)\x0d\x0arollback tran\x0d\x0aend\x0d\x0ago\x0d\x0a实例2:update触发器\x0d\x0acreate trigger tri_update\x0d\x0aon student\x0d\x0afor update\x0d\x0aas\x0d\x0aif update(student_id)\x0d\x0abegin\x0d\x0araiserror('学号不能修改!',16,8)\x0d\x0arollback tran\x0d\x0aend\x0d\x0ago\x0d\x0a实例3:delete触发器示\x0d\x0acreate trigger tri_delete\x0d\x0aon student\x0d\x0afor delete\x0d\x0aas\x0d\x0adeclare @student_id varchar(10)\x0d\x0aselect @student_id=student_id from deleted\x0d\x0aif @student_id='admin'\x0d\x0abegin\x0d\x0araiserror('错误',16,8)\x0d\x0arollback tran\x0d\x0aend触发器是一种特殊类型的存储过程,当使用下面的一种或多种数据修改 *** 作在指定表中对数据进行修改时,触发器会生效:UPDATE、INSERT 或 DELETE。触发器可以查询其它表,而且可以包含复杂的 SQL 语句。它们主要用于强制复杂的业务规则或要求。例如,可以控制是否允许基于顾客的当前帐户状态插入定单。
触发器还有助于强制引用完整性,以便在添加、更新或删除表中的行时保留表之间已定义的关系。然而,强制引用完整性的最好方法是在相关表中定义主键和外键约束。如果使用数据库关系图,则可以在表之间创建关系以自动创建外键约束。
触发器的优点如下:
1、触发器是自动的:它们在对表的数据作了任何修改(比如手工输入或者应用程序采取的 *** 作)之后立即被激活;
2、触发器可以通过数据库中的相关表进行层叠更改。例如,可以在 titles 表的 title_id 列上写入一个删除触发器,以使其它表中的各匹配行采取删除 *** 作。该触发器用 title_id 列作为唯一键,在 titleauthor、sales 及 roysched 表中对各匹配行进行定位;
3、触发器可以强制限制,这些限制比用 CHECK 约束所定义的更复杂。与 CHECK 约束不同的是,触发器可以引用其它表中的列。例如,触发器可以回滚试图对价格低于 10 美元的书(存储在 titles 表中)应用折扣(存储在 discounts 表中)的更新。
触发器的分类:
1、DML( 数据 *** 纵语言 Data Manipulation Language)触发器:是指触发器在数据库中发生DML事件时将启用。DML事件即指在表或视图中修改数据的insert、update、delete语句;
2、DDL(数据定义语言 Data Definition Language)触发器:是指当服务器或数据库中发生(DDL事件时将启用。DDL事件即指在表或索引中的create、alter、drop语句也;
3、登陆触发器:是指当用户登录SQL SERVER实例建立会话时触发。
触发器的SQL Server实例:要求就是在AddTable这个表上创建一个Update触发器,语句为:
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)