首页 数据库 mysql教程 SQL SERVER 触发器介绍

SQL SERVER 触发器介绍

Jun 07, 2016 pm 05:54 PM
sql 触发器

触发器是一种特殊类型的存储过程,它不同于之前的我们介绍的存储过程。触发器主要是通过事件进行触发被自动调用执行的。而存储过程可以通过存储过程的名称被调用。

Ø 什么是触发器

触发器对表进行插入、更新、删除的时候会自动执行的特殊存储过程。触发器一般用在check约束更加复杂的约束上面。触发器和普通的存储过程的区别是:触发器是当对某一个表进行操作。诸如:update、insert、delete这些操作的时候,系统会自动调用执行该表上对应的触发器。SQL Server 2005中触发器可以分为两类:DML触发器和DDL触发器,其中DDL触发器它们会影响多种数据定义语言语句而激发,这些语句有create、alter、drop语句。

DML触发器分为:

1、 after触发器(之后触发)

a、 insert触发器

b、 update触发器

c、 delete触发器

2、 instead of 触发器 (之前触发)

其中after触发器要求只有执行某一操作insert、update、delete之后触发器才被触发,且只能定义在表上。而instead of触发器表示并不执行其定义的操作(insert、update、delete)而仅是执行触发器本身。既可以在表上定义instead of触发器,也可以在视图上定义。

触发器有两个特殊的表:插入表(instered表)和删除表(deleted表)。这两张是逻辑表也是虚表。有系统在内存中创建者两张表,不会存储在数据库中。而且两张表的都是只读的,只能读取数据而不能修改数据。这两张表的结果总是与被改触发器应用的表的结构相同。当触发器完成工作后,这两张表就会被删除。Inserted表的数据是插入或是修改后的数据,而deleted表的数据是更新前的或是删除的数据。

Update数据的时候就是先删除表记录,然后增加一条记录。这样在inserted和deleted表就都有update后的数据记录了。注意的是:触发器本身就是一个事务,所以在触发器里面可以对修改数据进行一些特殊的检查。如果不满足可以利用事务回滚,撤销操作。

Ø 创建触发器

语法

  tgr_name<br> table_name<br> encrypion –加密触发器<br>   ...<br><br>  Transact-SQL
登录后复制

# 创建insert类型触发器

--创建insert插入类型触发器<br> (object_id(, )   )<br>    tgr_classes_insert<br><br>  tgr_classes_insert<br> classes<br>   insert --插入触发<br><br>  --定义变量<br>   @id , @name (20), @temp ;<br>  --在inserted表中查询已经插入记录信息<br>   @id = id, @name = name  inserted;<br>   @name = @name + (, @id);<br>   @temp = @id / 2;  <br>  insert  student (@name, 18 + @id, @temp, @id);<br>   ;<br><br>--插入数据<br>insert  classes (, getDate());<br>--查询数据<br> *  classes;<br> *  student   id;
登录后复制

insert触发器,会在inserted表中添加一条刚插入的记录。

# 创建delete类型触发器

--delete删除类型触发器<br> (object_id(, )   )<br>    tgr_classes_delete<br><br>  tgr_classes_delete<br> classes<br>    --删除触发<br><br>   ;  <br>   (object_id(, )   )<br>    --存在classesBackup,直接插入数据<br>    insert  classesBackup  name, createDate  deleted;<br>  <br>    --不存在classesBackup创建再插入<br>     *  classesBackup  deleted;<br>   ;<br><br><br><br>-- nocount ;<br> classes  name = ;<br>--查询数据<br> *  classes;<br> *  classesBackup;
登录后复制

delete触发器会在删除数据的时候,将刚才删除的数据保存在deleted表中。

# 创建update类型触发器

--update更新类型触发器<br> (object_id(, )   )<br>    tgr_classes_update<br><br>  tgr_classes_update<br> classes<br>   <br><br>   @oldName (20), @newName (20);<br>  --更新前的数据<br>   @oldName = name  deleted;<br>   ( ( *  student  name  + @oldName + ))<br>    <br>      --更新后的数据<br>       @newName = name  inserted;<br>       student  name = replace(name, @oldName, @newName)  name  + @oldName + ;<br>       ;<br>    <br>  <br>     ;<br><br>--查询数据<br> *  student   id;<br> *  classes;<br> classes  name =   name = ;
登录后复制

update触发器会在更新数据后,将更新前的数据保存在deleted表中,更新后的数据保存在inserted表中。

# update更新列级触发器

 (object_id(, )   )<br>    tgr_classes_update_column<br><br>  tgr_classes_update_column<br> classes<br>   <br><br>  --列级触发器:是否更新了班级创建时间<br>   ((createDate))<br>  <br>    (, 16, 11);<br>     ;<br>  <br><br>--测试<br> *  student   id;<br> *  classes;<br> classes  createDate = getDate()  id = 3;<br> classes  name =   id = 7;
登录后复制

更新列级触发器可以用update是否判断更新列记录;

# instead of类型触发器

instead of触发器表示并不执行其定义的操作(insert、update、delete)而仅是执行触发器本身的内容。

创建语法

  tgr_name<br> table_name<br> encryption<br>  instead  ...<br><br>  T-SQL
登录后复制

# 创建instead of触发器

 (object_id(, )   )<br>    tgr_classes_inteadOf<br><br>  tgr_classes_inteadOf<br> classes<br>  instead  <br><br>   @id , @name (20);<br>  --查询被删除的信息,病赋值<br>   @id = id, @name = name  deleted;<br>    + (, @id) +  + @name;<br>  --先删除student的信息<br>   student  cid = @id;<br>  --再删除classes的信息<br>   classes  id = @id;<br>    + (, @id) +  + @name + ;<br><br>--test<br> *  student   id;<br> *  classes;<br> classes  id = 7;
登录后复制

# 显示自定义消息raiserror

 (object_id(, )   )<br>    tgr_message<br><br>  tgr_message<br> student<br>   insert, <br> (, 16, 10);<br><br>--test<br>insert  student (, 22, 1, 7);<br> student  sex = 0  name = ;<br> *  student   id;
登录后复制

# 修改触发器

  tgr_message<br> student<br> <br> (, 16, 10);<br><br>--test<br>  student  name = ;
登录后复制

# 启用、禁用触发器

--禁用触发器<br>disable  tgr_message  student;<br>--启用触发器<br>enable  tgr_message  student;
登录后复制

# 查询创建的触发器信息

--查询已存在的触发器<br> *  sys.triggers;<br> *  sys.objects  type = ;<br><br>--查看触发器触发事件<br> te.*  sys.trigger_events te  sys.triggers t<br> t.object_id = te.object_id<br> t.parent_class = 0  t.name = ;<br><br>--查看创建触发器语句<br> sp_helptext ;
登录后复制
# 示例,验证插入数据
 ((object_id(, )   ))<br>    tgr_valid_data<br><br>  tgr_valid_data<br> student<br> insert<br><br>   @age ,<br>      @name (20);<br>   @name = s.name, @age = s.age  inserted s;<br>   (@age   <br>    (, 16, 1);<br>     ;<br>  <br><br>--test<br>insert  student (, 2, 0, 7);<br>insert  student (, 22, 0, 7);<br> *  student   id;
登录后复制

# 示例,操作日志

(object_id(, ) )
log

log(
id (1, 1) ,
(20),
createDate datetime getDate()
)

( ( * sys.objects name = ))
tgr_student_log

tgr_student_log
student
insert, ,

(( ( 1 inserted)) ( ( 1 deleted)))

insert log() ();

( ( 1 inserted) ( 1 deleted))

insert log() ();

( ( 1 inserted) ( 1 deleted))

insert log() ();


--test
insert student (, 22, 1, 7);
student sex = 0 name = ;
student name = ;
* log;
* student id;

本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

AI Hentai Generator

AI Hentai Generator

免费生成ai无尽的。

热门文章

R.E.P.O.能量晶体解释及其做什么(黄色晶体)
3 周前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳图形设置
3 周前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您听不到任何人,如何修复音频
3 周前 By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25:如何解锁Myrise中的所有内容
4 周前 By 尊渡假赌尊渡假赌尊渡假赌

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

Hibernate 框架中 HQL 和 SQL 的区别是什么? Hibernate 框架中 HQL 和 SQL 的区别是什么? Apr 17, 2024 pm 02:57 PM

HQL和SQL在Hibernate框架中进行比较:HQL(1.面向对象语法,2.数据库无关的查询,3.类型安全),而SQL直接操作数据库(1.与数据库无关的标准,2.可执行复杂查询和数据操作)。

Oracle SQL中除法运算的用法 Oracle SQL中除法运算的用法 Mar 10, 2024 pm 03:06 PM

《OracleSQL中除法运算的用法》在OracleSQL中,除法运算是常见的数学运算之一。在数据查询和处理过程中,除法运算可以帮助我们计算字段之间的比例或者得出特定数值的逻辑关系。本文将介绍OracleSQL中除法运算的用法,并提供具体的代码示例。一、OracleSQL中除法运算的两种方式在OracleSQL中,除法运算可以使用两种不同的方式进行

Oracle和DB2的SQL语法比较与区别 Oracle和DB2的SQL语法比较与区别 Mar 11, 2024 pm 12:09 PM

Oracle和DB2是两个常用的关系型数据库管理系统,它们都有自己独特的SQL语法和特点。本文将针对Oracle和DB2的SQL语法进行比较与区别,并提供具体的代码示例。数据库连接在Oracle中,使用以下语句连接数据库:CONNECTusername/password@database而在DB2中,连接数据库的语句如下:CONNECTTOdataba

详解MyBatis动态SQL标签中的Set标签功能 详解MyBatis动态SQL标签中的Set标签功能 Feb 26, 2024 pm 07:48 PM

MyBatis动态SQL标签解读:Set标签用法详解MyBatis是一个优秀的持久层框架,它提供了丰富的动态SQL标签,可以灵活地构建数据库操作语句。其中,Set标签是用于生成UPDATE语句中SET子句的标签,在更新操作中非常常用。本文将详细解读MyBatis中Set标签的用法,以及通过具体的代码示例来演示其功能。什么是Set标签Set标签用于MyBati

SQL中的identity属性是什么意思? SQL中的identity属性是什么意思? Feb 19, 2024 am 11:24 AM

SQL中的Identity是什么,需要具体代码示例在SQL中,Identity是一种用于生成自增数字的特殊数据类型,它常用于唯一标识表中的每一行数据。Identity列通常与主键列配合使用,可以确保每条记录都有一个独一无二的标识符。本文将详细介绍Identity的使用方式以及一些实际的代码示例。Identity的基本使用方式在创建表时,可以使用Identit

SQL出现5120错误怎么解决 SQL出现5120错误怎么解决 Mar 06, 2024 pm 04:33 PM

解决办法:1、检查登录用户是否具有足够的权限来访问或操作该数据库,确保该用户具有正确的权限;2、检查SQL Server服务的帐户是否具有访问指定文件或文件夹的权限,确保该帐户具有足够的权限来读取和写入该文件或文件夹;3、检查指定的数据库文件是否已被其他进程打开或锁定,尝试关闭或释放该文件,并重新运行查询;4、尝试以管理员身份运行Management Studio等等。

如何使用SQL语句在MySQL中进行数据聚合和统计? 如何使用SQL语句在MySQL中进行数据聚合和统计? Dec 17, 2023 am 08:41 AM

如何使用SQL语句在MySQL中进行数据聚合和统计?在进行数据分析和统计时,数据聚合和统计是非常重要的步骤。MySQL作为一个功能强大的关系型数据库管理系统,提供了丰富的聚合和统计函数,可以很方便地进行数据聚合和统计操作。本文将介绍使用SQL语句在MySQL中进行数据聚合和统计的方法,并提供具体的代码示例。一、使用COUNT函数进行计数COUNT函数是最常用

数据库技术大比拼:Oracle和SQL的区别有哪些? 数据库技术大比拼:Oracle和SQL的区别有哪些? Mar 09, 2024 am 08:30 AM

数据库技术大比拼:Oracle和SQL的区别有哪些?在数据库领域中,Oracle和SQLServer是两种备受推崇的关系型数据库管理系统。尽管它们都属于关系型数据库的范畴,但两者之间存在着诸多不同之处。在本文中,我们将深入探讨Oracle和SQLServer之间的区别,以及它们在实际应用中的特点和优势。首先,Oracle和SQLServer在语法方面存

See all articles