15、SQL Server 触发器
SQL Server 触发器
触发器是一种特殊的存储过程,只有当试图用数据操作语言DML来修改数据时才会触发,DML包含对视图和表的增、删、改。
触发器分为DML触发器和DDL触发器,其中DML触发器会对数据表,视图进行insert、update、delete的时候触发。DDL则是create、alter、drop等时触发。
DML触发器又分为after(之后触发)和insert of(之前触发)触发器。
如果在创建触发器的时候不指定类型,则默认是after触发器。
触发器有两个虚拟的临时表:插入表(inserted)和删除表(deleted),由系统在内存中创建,不会保存到数据库。并且两张表都是只读的。当触发器完成工作后,这两张表会自动删除。
增加:inserted表 记录
删除:deleted表 记录
修改:inserted表记录修改前 deleted表记录修改后
修改数据时现删掉该记录,然后再增加一天新的记录。这样inserted和updated就都存在记录了。
触发器本身就是一个事务,可以利用事务的回滚,撤销操作。事务就是要么都执行,要么一条都不执行。
创建触发器
语法:
create trigger [shema_name . ] trg_name
on { table | view }
[ with encryption ]
{ for | after | instead of }
{ insert , update , delete }
as
sql_statement
创建insert触发器
if(object_id('tgr_test_insert','tr') is not null)
drop trigger tgr_test_insert --删除触发器
go
create trigger tgr_test_insert
on student --创建在student表
for insert --insert触发
as
declare @id int,@name varchar(20),@sex char(2),@age int
--查询inserted表中已经插入的信息
select @id = id,@name = name,@sex = sex, @age = age from inserted
--用查到的信息加入到会员表中
if(@age >30) --如果年龄不符合 则修改
begin
update student set age = 30 where id = @id
print '年龄太大,已自动修改为30'
end
insert into [user] (userName,passWord,RoleId) values (@name,@sex + cast(@age as varchar),3)
print '添加学生成功!';
print '添加会员成功!'
对student表创建触发器后对该表执行insert后
insert into student (name,sex,age,mail) values ('海盗船长','男',88,'853020304@qq.com')

查看运行结果

创建update触发器
if(object_id('tgr_student_update','tr') is not null)
drop trigger tgr_student_update
go
create trigger tgr_student_update
on student
for update
as
declare @oldName varchar(10),@newName varchar(10)
select @oldName = name from deleted; --查找更新前的数据
select @newName = name from inserted;--查找更新后的数据
if(@oldName = @newName)
begin
print '数据相同'
rollback tran; --回滚 不执行修改操作
end
else
print '修改成功'
update student set name='海盗船长'
事务在触发器中结束。批处理已中止。
update student set name='粉红娘娘'
修改成功
创建delete触发器
if(object_id('tgr_student_delete','tr')is not null)
drop trigger tgr_student_delete
go
create trigger tgr_student_delete
on student
for delete
as
if(exists(select * from sys.databases where name = 'studentBackup'))
insert into studentBackup select name,sex,age,mail from deleted;
else
print '不存在,创建再插入'
create table studentBackup
(
name varchar(20),
sex char(2),
age int,
mail varchar(20)
)
insert into studentBackup select name,sex,age,mail from deleted;
delete from student select * from student
select * from studentBackup

创建instead of触发器
if(object_id('tgr_student_inteadof','tr') is not null)
drop trigger tgr_student_inteadof
go
create trigger tgr_student_inteadof
on student
instead of delete -- update , insert
as
declare @id int,@name varchar(20)
select @id = id,@name = name from deleted;
--instead of 先触发
--先删除user表信息
delete from [user] where userName = @name;
--再删除student表信息
delete from [student] where id = @id;
delete from student where name = '海盗船长'
修改触发器
alter trigger tgr_test_insert
on student
for insert
as
print 'ok'
禁用触发器
disable trigger tgr_test_insert on student
启用触发器
enable trigger tgr_test_insert on student
查询已创建的触发器
select * from sys.triggers
15、SQL Server 触发器的更多相关文章
- sql server触发器的例子
发布:thebaby 来源:脚本学堂 [大 中 小] 本文介绍下,在sql server数据库中使用触发器的简单例子,有需要的朋友可以参考下,希望对你有一定的帮助. 原文地址:http:/ ...
- (转)SQL Server 触发器
SQL Server 触发器 触发器是一种特殊类型的存储过程,它不同于之前的我们介绍的存储过程.触发器主要是通过事件进行触发被自动调用执行的.而存储过程可以通过存储过程的名称被调用. Ø 什么是触发器 ...
- 自己写的sql server触发器练练--高手请您跳过吧
set ANSI_NULLS ONset QUOTED_IDENTIFIER ONgo ALTER TRIGGER [insertReplyToic] ON [dbo].[bbsReplyTopic] ...
- sql server 触发器详细应用
SQL Server 触发器 触发器是一种特殊类型的存储过程,它不同于之前的我们介绍的存储过程.触发器主要是通过事件进行触发被自动调用执行的.而存储过程可以通过存储过程的名称被调用. Ø 什么是触发 ...
- SQL server触发器中 update insert delete 分别给写个例子被。
SQL server触发器中 update insert delete 分别给写个例子以及解释下例子的作用和意思被, 万分感谢!!!! 主要想知道下各个语句的书写规范. INSERT: 表1 (ID, ...
- 在Sql Server触发器中判断操作是Insert还是Update还是Delete
在Sql Server触发器中判断操作是Insert还是Update还是Delete DECLARE @IsInsert bit, @IsUpdate bit, @IsDelete ...
- 喜忧参半的SQL Server触发器
SQL Server触发器在非常有争议的主题.它们能以较低的成本提供便利,但经常被开发人员.DBA误用,导致性能瓶颈或维护性挑战. 本文简要回顾了触发器,并深入讨论了如何有效地使用触发器,以及何时触发 ...
- SQL Server 触发器创建、删除、修改、查看示例
一﹕ 触发器是一种特殊的存储过程﹐它不能被显式地调用﹐而是在往表中插入记录﹑更新记录或者删除记录时被自动地激活.所以触发器可以用来实现对表实施复杂的完整性约`束. 二﹕ SQL Server为每个触发 ...
- SQL Server触发器
一﹕ 触发器是一种特殊的存储过程﹐它不能被显式地调用﹐而是在往表中插入记录﹑更新记录或者删除记录时被自动地激活.所以触发器可以用来实现对表实施复杂的完整性约`束. 二﹕ SQL Server为每个触发 ...
随机推荐
- bzoj 1191: [HNOI2006]超级英雄Hero 并查集 || 匈牙利算法
1191: [HNOI2006]超级英雄Hero Time Limit: 10 Sec Memory Limit: 162 MBSubmit: 1804 Solved: 850[Submit][S ...
- 使用Unity游戏引擎在IOS模拟器中运行的方法
在Unity编译IOS程序时,在Unity导航栏菜单中选择Edit->ProjectSettings ->Player(菜单项)选择IOS平台在下方SDK Version处选择运行设备为I ...
- android的原理,为什么不需要手动关闭程序
转自android的原理,为什么不需要手动关闭程序 不用在意剩余内存的大小,其实很多人都是把使用其他系统的习惯带过来来了. Andoird大多应用没有退出的设计其实是有道理的,这和系统对进程的调度机制 ...
- Android假退出不是流氓行为
转自Android假退出不是流氓行为 关于Android程序的退出,目前我们没有再用System.exit(0)或killProcess的机制而是直接用Activity.finish假退出了.因此在内 ...
- RSA算法原理(二)
上一次,我介绍了一些数论知识. 有了这些知识,我们就可以看懂RSA算法.这是目前地球上最重要的加密算法. 六.密钥生成的步骤 我们通过一个例子,来理解RSA算法.假设爱丽丝要与鲍勃进行加密通信,她该怎 ...
- 孤陋寡闻又一遭:ReportEvent API函数(有微软Service官方例子为例)
API 详解: https://msdn.microsoft.com/en-us/library/windows/desktop/aa363679(v=vs.85).aspx 使用例子: https: ...
- maya绝招(1-20)
第一招 自制MAYA启动界面 在安装目录下的BIN文件夹中的MayaRes.dll文件,用Resource Hacker打开.在软件的目录树中找到“位图”下的MAYASTARTUPIMAGE.XPM并 ...
- OC语言中类目,延展,协议
一.类目 指向已知的类中添加新方法,不破坏封装性.已知类可以是自定义的类和系统的类. 1.类目的实现和声明 建一个学生类,并增加类目 (1).声明(是在Student+Working.h中) 必须引入 ...
- Android View 事件分发机制详解
想必很多android开发者都遇到过手势冲突的情况,我们一般都是通过内部拦截和外部拦截法解决此类问题.要想搞明白原理就必须了解View的分发机制.在此之前我们先来了解一下以下三个非常重要的方法: di ...
- [Hibernate] 注解映射例子
Hibernate 注解(Hibernate Annotation) 是一种比较新的方式,通过在 java 简单类增加注解,来声明 java 类和数据库表的映射,作用和 xml 文件相似.hibern ...