sql触发器实例 各类触发器的特点?
各类触发器的特点?
触发器是SQL server提供给程序员和数据分析人员的一种方法,用于确保数据完整性。它是一个与表事件相关的特殊存储过程。它的执行不是由程序调用或手动启动的,而是由事件触发的。例如,当一个表被操作(insert、delete、update)时,它的执行将被激活。触发器通常用于强制执行数据完整性约束和业务规则。触发器可用于在写入数据表之前强制验证或转换数据。当触发错误发生时,更改的结果将被撤销。一些数据库管理系统可以将触发器用于数据定义语言(DDL),称为DDL触发器。可根据具体情况更换。sqlserver包括三种触发器:DML触发器、DDL触发器和login触发器。
1. DML触发器当数据库表中的数据发生变化时,包括insert、update、delete等任何操作,如果我们将相应的DML触发器写入表中,那么触发器将自动执行。DML触发器的主要功能是执行业务规则并扩展sqlserver约束和默认值。因为我们知道约束只能约束同一个表中的数据,任意SQL命令都可以在触发器中执行。
2. DDL触发器是sqlserver2005中的一个新触发器。主要用于对数据库中的表、触发器、视图等结构的操作进行审计和标准化。例如,在修改表、修改列、添加表、添加列等。它是在数据库结构发生变化时实现的。我们主要用它来记录数据库的修改过程,并限制程序员对数据库的修改,比如不允许删除一些指定的表。
3. Login触发器Login触发器触发存储过程以响应登录事件。在与SQL server实例建立用户会话时引发此事件。登录触发器在登录的身份验证阶段完成之后和用户会话实际建立之前触发。因此,所有来自触发器内部并通常到达用户的消息(如错误消息和来自print语句的消息)都会发送到sqlserver错误日志。如果身份验证失败,则不会触发登录触发器。
版权声明:本文内容由互联网用户自发贡献,本站不承担相关法律责任.如有侵权/违法内容,本站将立刻删除。