b2科目四模拟试题多少题驾考考爆了怎么补救
b2科目四模拟试题多少题 驾考考爆了怎么补救

SQL Server 触发器实例详解

电脑杂谈  发布时间:2020-02-03 20:01:30  来源:网络整理

sql server 2008 应用配置器_sql2008触发器实例_sql server 2008 实例教程

Microsoft SQL Server 2000 提供了两种主要模式来强行业务规则跟数据完整性:约束和触发器。触发器是一种特殊种类的存储过程,它不同于之前的我们介绍的存储过程。触发器主要是借助事件进行触发被手动调用执行的。而存储过程可以借助存储过程的名称被调用。

什么是触发器

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

优点

触发器可借助中的相关表实现级联更改;通过级联引用完整性约束可以更有效地执行某些修改。

触发器可以强制比用 CHECK 约束定义的约束更为复杂的约束。

与 CHECK 约束不同,触发器可以引用其他表中的列。例如,触发器可以使用另一个表中的 SELECT 比较插入或升级的数据,以及执行其他操作,如设置数据或显示用户定义错误信息。

触发器也可以检测数据更改前后的表状态,并按照其变化采取对策。

DML触发器分为:

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

sql2008触发器实例_sql server 2008 实例教程_sql server 2008 应用配置器

a、 insert触发器

b、 update触发器

c、 delete触发器

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

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

触发器有两个特殊的表:插入表(instered表)和删除表(deleted表)。这两张是逻辑表也有虚表。有平台在存储中创建者两张表,不会存储在中。而且两张表的都是只读的,只能写入数据而不能修改数据。这两张表的结果总是与被改触发器应用的表的构架相同。当触发器完成工作后,这两张表都会被删除。Inserted表的数据是插入或是设置后的数据sql2008触发器实例,而deleted表的数据是升级前的或是删除的数据。

SQL Server 触发器实例详解

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

创建触发器

语法

sql server 2008 实例教程_sql2008触发器实例_sql server 2008 应用配置器

create trigger tgr_nameon table_namewith encrypion –加密触发器 for update...as Transact-SQL

# 创建insert类型触发器

--创建insert插入类型触发器if (object_id('tgr_classes_insert', 'tr') is not null) drop trigger tgr_classes_insertgocreate trigger tgr_classes_inserton classes for insert --插入触发as --定义变量 declare @id int, @name varchar(20), @temp int; --在inserted表中查询已经插入记录信息 select @id = id, @name = name from inserted; set @name = @name + convert(varchar, @id); set @temp = @id / 2; insert into student values(@name, 18 + @id, @temp, @id); print '添加学生成功!';go--插入数据insert into classes values('5班', getDate());--查询数据select * from classes;select * from student order by id; 

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

# 创建delete类型触发器

--delete删除类型触发器if (object_id('tgr_classes_delete', 'TR') is not null) drop trigger tgr_classes_deletegocreate trigger tgr_classes_deleteon classes for delete --删除触发as print '备份数据中……'; if (object_id('classesBackup', 'U') is not null) --存在classesBackup,直接插入数据 insert into classesBackup select name, createDate from deleted; else --不存在classesBackup创建再插入 select * into classesBackup from deleted; print '备份数据成功!';go----不显示影响行数--set nocount on;delete classes where name = '5班';--查询数据select * from classes;select * from classesBackup; 

delete触发器会在删除数据的之后,将先前删除的数据保存在deleted表中。

# 创建update类型触发器

--update更新类型触发器if (object_id('tgr_classes_update', 'TR') is not null) drop trigger tgr_classes_updategocreate trigger tgr_classes_updateon classes for updateas declare @oldName varchar(20), @newName varchar(20); --更新前的数据 select @oldName = name from deleted; if (exists (select * from student where name like '%'+ @oldName + '%')) begin --更新后的数据 select @newName = name from inserted; update student set name = replace(name, @oldName, @newName) where name like '%'+ @oldName + '%'; print '级联修改数据成功!'; end else print '无需修改student表!';go--查询数据select * from student order by id;select * from classes;update classes set name = '五班' where name = '5班'; 

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

sql server 2008 应用配置器_sql server 2008 实例教程_sql2008触发器实例

# update更新列级触发器

if (object_id('tgr_classes_update_column', 'TR') is not null) drop trigger tgr_classes_update_columngocreate trigger tgr_classes_update_columnon classes for updateas --列级触发器:是否更新了班级创建时间 if (update(createDate)) begin raisError('系统提示:班级创建时间不能修改!', 16, 11); rollback tran; endgo--测试select * from student order by id;select * from classes;update classes set createDate = getDate() where id = 3;update classes set name = '四班' where id = 7; 

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

# instead of类型触发器

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

创建语法

create trigger tgr_nameon table_namewith encryption instead of update...as T-SQL 

# 创建instead of触发器

if (object_id('tgr_classes_inteadOf', 'TR') is not null) drop trigger tgr_classes_inteadOfgocreate trigger tgr_classes_inteadOfon classes instead of delete/*, update, insert*/as declare @id int, @name varchar(20); --查询被删除的信息,病赋值 select @id = id, @name = name from deleted; print 'id: ' + convert(varchar, @id) + ', name: ' + @name; --先删除student的信息 delete student where cid = @id; --再删除classes的信息 delete classes where id = @id; print '删除[ id: ' + convert(varchar, @id) + ', name: ' + @name + ' ] 的信息成功!';go--testselect * from student order by id;select * from classes;delete classes where id = 7; 

# 显示自定义消息raiserror

sql2008触发器实例_sql server 2008 应用配置器_sql server 2008 实例教程

if (object_id('tgr_message', 'TR') is not null) drop trigger tgr_messagegocreate trigger tgr_messageon student after insert, updateas raisError('tgr_message触发器被触发', 16, 10);go--testinsert into student values('lily', 22, 1, 7);update student set sex = 0 where name = 'lucy';select * from student order by id;

# 修改触发器

alter trigger tgr_messageon studentafter deleteas raisError('tgr_message触发器被触发', 16, 10);go--testdelete from student where name = 'lucy';

# 启用、禁用触发器

--禁用触发器disable trigger tgr_message on student;--启用触发器enable trigger tgr_message on student;


本文来自电脑杂谈,转载请注明本文网址:
http://www.pc-fly.com/a/jisuanjixue/article-139502-1.html

相关阅读
    发表评论  请自觉遵守互联网相关的政策法规,严禁发布、暴力、反动的言论

    热点图片
    拼命载入中...