SQL Server 触发器
Posted gcczhongduan
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了SQL Server 触发器相关的知识,希望对你有一定的参考价值。
SQLServer触发器创建、删除、改动、查看
比方你在更新一个表的某条数据的时候,你就触发了你之前已经定义好了的一个after update 类型的触发器。
这里触发器里面你能够“将另外一个表与之关联的数据也跟新了”或者干些别的事情。等等,你要你想干的事。都能够。
所以触发器能够用来实现对表实施复杂的完整性约束。
二: SQL Server为每一个触发器都创建了两个专用表:Inserted表和Deleted表。两个表由系统来维护﹐它们存在于内存中而不是在数据库中。这两个表的结构总是与被该触发器作用的表的结构同样。
触发器运行 完毕后﹐与该触发器相关的这两个表也被删除。
Deleted表存放因为运行Delete或Update语句而要从表中删除的全部行。
Inserted表存放因为运行Insert或Update语句而要向表中插入的全部行。
SQL Server 包含三种常规类型的触发器:DML 触发器、DDL 触发器和登录触发器。
本文主要讲述DML触发器,DML触发器有两种:AFTER,INSTEAD OF触发器。同一时候DML 触发器使用 deleted 和 inserted 逻辑(概念)表。 它们在结构上类似于定义了触发器的表,即对其尝试运行了用户操作的表。
在 deleted 和 inserted 表保存了可能会被用户更改的行的旧值或新值。
- 对于INSERT 操作,inserted保留新增的记录,deleted无记录
- 对于DELETE 操作,inserted无记录,deleted保留被删除的记录
- 对于UPDATE操作。inserted保留改动后的记录,deleted保留改动前的记录
INSTEAD OF 触发器表示并不运行其所定义的操作(INSERT、 UPDATE、 DELETE),而仅是运行触发器本身。既可在表上定义INSTEAD OF 触发器,也能够在视图上定义INSTEAD OF 触发器。但对同一操作仅仅能定义一个INSTEAD OF 触发器。
(1)AFTER触发器:它是在运行INSERT、UPDATE、DELETE语句操作之后运行触发器操作。它主要是用于记录变更后的处理或检查,一旦错误发生,能够用Rollback Transaction语句来回滚本次扣件,只是不能对视图定义AFTER触发器。
(2)INSTEAD OF触发器:它在运行INSERT、UPDATE、DELETE语句操作之前运行触发器本身所定义的操作。而INSTEAD OF触发器是能够定义在视图上的。
<1>
--向表“j0261”插入数据时,检查学号是否存在于表“j026”中,如存在则进行插入操作,否则就不插入。 create trigger checkid on j0261 --创建一个名字为checkid的触发器,作用的表是j0261 instead of insert as if(not exists(slect * from j026 where 学号=(select 学号 from inserted)))--假设插入j0261的那一条数据里的\'学号\'不存在j026表里 rollback transaction --将显式事务或隐性事务回滚到事务的起点或事务内的某个保存点 print \'要处理记录的学号不存在\' else insert into j0261 select * from inserted print \'记录插入成功\' 实例: --常见的触发器有三种:分别应用于Insert , Update , Delete 事件。use DataStudent --指定数据库 create table Student --创建表 ( studentID int primary key --学号 ) go create table BorrowRecord --创建表 ( [BorrowRecord] int identity(1,1),--自增表示列,流水号 StudentID int, --学号 BorrowDate datetime, --借出时间 ReturnDate datetime --归还时间 ) go --1.假设我更改了学生的学号,我希望他的借书记录仍然与这个学生相关(也就是同一时候更改借书记录表的学号); --2.假设该学生已经毕业,我希望删除他的学号的同一时候,也删除它的借书记录。 --触发器1 IF(EXISTS (SELECT * FROM sys.objects WHERE name=\'Tri_Student_update\')) drop trigger truStudent go create Trigger Tri_Student_update on Student for update --假设仅指定 FOR keyword。则 AFTER 为默认值。即:for updae能够写成after update。For 是触发器默认的触发点,默觉得AFTER。所以最好直接用AFTER,由于即便用For的话。编译器也会自己主动编译转换变成AFTER。 as if UPDATE(studentID) --假设这个studentID字段被更新的话 begin declare @oldID int,@newsID int select @oldID=studentID from deleted --获取没有更新前的studentID select @newsID=studentID from inserted --获取更新后的studentID update BorrowRecord set studentID =@newsID WHERE studentID=@oldID end --触发器2 if(exists(select * from sys.objects where name=\'Tri_student_delete\')) drop Trigger trdStudent go create Trigger Tri_student_delete on Student for delete --假设仅指定 FOR keyword,则 AFTER 为默认值。即:for delete能够写成after delete as begin declare @oldID int select @oldID=studentID from deleted --获取没有删除前的studentID delete from BorrowRecord where StudentID=@oldID end -----------------------------------------------------------------------重点。效果 --运行下面update语句,就会在更新Student表的同一时候BorrowRecord表里的studentID也会一块得到更新 UPDATE Student SET studentID=3 where studentID=1 go --运行下面delete语句,就会在删除Student表某行时BorrowRecord表里相应的字段的\'行\'也会得到删除 delete from Student where studentID=3 go --select * from Student --select * from BorrowRecord --go
以上是关于SQL Server 触发器的主要内容,如果未能解决你的问题,请参考以下文章
使用实体框架迁移时 SQL Server 连接抛出异常 - 添加代码片段