SQL触发器

什么是触发器?
触发器是一种用来保障参照完整性的特殊的存储过程,它维护不同表中数据间关系的有关规则。当对指定的表进行某种特定操作(如:Insert,Delete或Update)时,触发器产生作用。触发器可以调用存储过程。

常见的触发器有三种:分别应用于Insert,Update,Delete事件。

触发器的限制:

1、一个表最多只能有三个触发器,insert,update,delete
2、每个触发器只能用于一个表
3、不能对视图、临时表创建触发器
4、Truncate table能删除表,但不能触发触发器
5、不能将触发器用于系统表

使用触发器的优点
1、触发器是自动的:它们在对表的数据作了任何修改(比如手工输入或者应用程序采取的操作)之后立即被激活。
2、触发器可以通过数据库中的相关表进行层叠更改。例如,可以在 titles 表的 title_id 列上写入一个删除触发器,以使其它表中的各匹配行采取删除操作。该触发器用 title_id 列作为唯一键,在 titleauthor、sales 及 roysched 表中对各匹配行进行定位。
3、触发器可以强制限制,这些限制比用 CHECK 约束所定义的更复杂。与 CHECK 约束不同的是,触发器可以引用其它表中的列。例如,触发器可以回滚试图对价格低于 10 美元的书(存储在 titles 表中)应用折扣。

--删除触发器
drop trigger 触发器名称
--判断触发器是否存在
if (object_id('触发器名') is not null)
    --删除触发器
    drop trigger 触发器名
go
--创建触发器
if (object_id('触发器名') is not null)
    drop trigger 触发器名
go
Create Trigger 触发器名
On 表名
For insert/update/delete
As
Begin
SQL语句(块)
End

下面在数据表上进行操作触发器,首先创建一个数据表TestTable

CREATE TABLE TestTable(
 [Id] [int] IDENTITY(1,1) NOT NULL,
 [UserName] [nvarchar](50) NULL,
 [Subject] [nvarchar](50) NULL,
 [Source] [numeric](18, 0) NULL
) ON [PRIMARY]
go
INSERT INTO TestTable ([UserName],[Subject],[Source]) 
 SELECT N'张三',N'语文',60 UNION ALL
 SELECT N'李四',N'数学',70 UNION ALL
 SELECT N'王五',N'英语',80 UNION ALL
 SELECT N'王五',N'数学',75 UNION ALL
 SELECT N'王五',N'语文',57 UNION ALL
 SELECT N'李四',N'语文',80 UNION ALL
 SELECT N'张三',N'英语',100
GO

1、创建insert插入类型触发器,用于判断插入的姓名是否存在,存在则插入失败进行回滚,不存在则插入成功,

--判断触发器tgr_insert是否存在
if (object_id('tgr_insert') is not null)
    --删除触发器tgr_insert
    drop trigger tgr_insert
go
--创建触发器tgr_insert
create trigger tgr_insert
--TestTable表示需要操作的表名
on TestTable
    for insert --插入触发
as
--定义变量
declare
@UserName nchar(20),
@Subject nchar(20),
@Source int,
@ishave int;
--给变量赋值
select @UserName=UserName,@Subject=Subject,@Source=Source from TestTable
--查询姓名相同的行数赋值给@ishave
select @ishave=COUNT(*) from TestTable where UserName=@UserName
--如果行数大于1表示该姓名已存在
if(@ishave>1)
begin
--print提示信息
print('插入失败,事务已回滚')
--事务数据回滚
Rollback transaction    
end
else
--否则该姓名不存在,则插入成功
print('插入成功')

--插入数据进行测试,执行两次看输出结果
insert into TestTable values('张三三','天文',200);

 

posted @ 2021-04-20 09:40  时光博客  阅读(394)  评论(0编辑  收藏  举报