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);
注:强推一波在线工具站点:在线小工具 | 欢迎大佬们访问哈~