sql触发器(insert,update,delete)
2015-08-06 10:55
330 查看
来源:http://blog.sina.com.cn/s/blog_78106bb101014nep.html
--insert 触发器
create trigger tri_insert
on student --将要进行更改的表名
for insert --给表插入一条数据的时候触发
as
declare @student_id char(10) --定义一个变量
select @student_id=s.student_id from --把查询出的指定字段的值赋值给变量
student s inner join inserted i
on s.student_id=i.student_id
if @student_id='0000000001'
begin
raiserror('不能插入1的学号!',16,8)
rollback tran
end
go
--update触发器
create trigger tri_update
on student --将要进行更改的表名
for update --给表修改一条数据的时候触发
as
if update(student_id)
begin
raiserror('学号不能修改!',16,8)
rollback tran
end
go
--delete触发器
create trigger tri_delete
on student --将要进行更改的表名
for delete --给表删除一条数据的时候触发
as
declare @student_id varchar(10)
select @student_id=student_id from deleted
if @student_id='admin'
begin
raiserror('错误',16,8)
rollback tran
end
解释:在删除(delete)数据的时候,可以假定数据库将要删除的数据放到一个deleted临时表中,我们可以向读取普通的表一样,select 字段 from deleted
而insert的时候道理一样,只不过是把要插入的数据放在inserted表中。
更新操作可以认为是执行了两个操作,先把那一行记录delete掉,然后再insert,这样update操作实际上就对deleted表和inserted表的操作,所以不会有updated表了,有的时候两个表是主外键关系,想删除主表数据的同时把子表相关的数据也删除,这个时候如果用触发器就没有效果了,因为这个触发器是在你删除表后才触发的,这个时候直接终止,提示“有主外键关系,不能删除等”,所有这样的删除触发器是没有效果的
--insert 触发器
create trigger tri_insert
on student --将要进行更改的表名
for insert --给表插入一条数据的时候触发
as
declare @student_id char(10) --定义一个变量
select @student_id=s.student_id from --把查询出的指定字段的值赋值给变量
student s inner join inserted i
on s.student_id=i.student_id
if @student_id='0000000001'
begin
raiserror('不能插入1的学号!',16,8)
rollback tran
end
go
--update触发器
create trigger tri_update
on student --将要进行更改的表名
for update --给表修改一条数据的时候触发
as
if update(student_id)
begin
raiserror('学号不能修改!',16,8)
rollback tran
end
go
--delete触发器
create trigger tri_delete
on student --将要进行更改的表名
for delete --给表删除一条数据的时候触发
as
declare @student_id varchar(10)
select @student_id=student_id from deleted
if @student_id='admin'
begin
raiserror('错误',16,8)
rollback tran
end
解释:在删除(delete)数据的时候,可以假定数据库将要删除的数据放到一个deleted临时表中,我们可以向读取普通的表一样,select 字段 from deleted
而insert的时候道理一样,只不过是把要插入的数据放在inserted表中。
更新操作可以认为是执行了两个操作,先把那一行记录delete掉,然后再insert,这样update操作实际上就对deleted表和inserted表的操作,所以不会有updated表了,有的时候两个表是主外键关系,想删除主表数据的同时把子表相关的数据也删除,这个时候如果用触发器就没有效果了,因为这个触发器是在你删除表后才触发的,这个时候直接终止,提示“有主外键关系,不能删除等”,所有这样的删除触发器是没有效果的
相关文章推荐
- redis 内存库设置 教你怎么解决64位Windows版Redis狂占C盘的问题.
- 数据库访问性能优化
- Redis常用命令——hash
- 局域网其他电脑连接测试机MySQL数据库
- SQL优化经验总结
- mysql关联查询
- oracle查看和更新统计表的信息
- 我如何调优SQL Server查询
- jdbc-connect-oracle12c-pdb/cdb(jdbc连接oracle12c的pdb和cdb)
- Linux运维 第四阶段 (一) MySQL基本概念及编译安装
- MySQL性能剖析
- MySQL性能剖析
- MySQL性能剖析
- redis集群安装以及jedis的实现
- Oracle11gr2新增APPEND_VALUES提示
- MongoDB集群读优先策略
- SQLAlchemy文档翻译第1章
- Sql 工资第二高(考虑并列)
- Sql 工资第二高(考虑并列)
- sql显示12个月数据