触发器
什么是触发器?
触发器是一个在修改表中的数据时执行的存储过程。通常通过创建触发器来实现不同表中的逻辑
相关数据的引用完整性或一致性。由于用户不能绕过触发器,所以可以用它来强制实施复杂的业
务规则,以确保数据的完整性。
触发器不同于存储过程。触发器主要是通过时间进行触发而被执行的,而存储过程可以通过存储
过程名字而被直接调用。当对某一表进行诸如update,insert,delete这些操作时,SLQ Server
就会自动执行触发器所定义的SQL语句,从而确保对数据的处理必须符合由这些SQL语句定义的
规则。
为什么使用触发器?
触发器自动执行,它们在表的数据作了任何修改(比如手工输入或者使用程序采集的操作)之
后立即激活。
触发器可以通过数据库中的相关表进行层叠更改。这比直接把代码写在前台的做法更合理更
安全。
触发器可以强制限制,这些限制比用check约束锁定义的更复杂。与check约束不同的是,
触发器可以引用其他表中的列。
触发器种类
DDL触发器:
DDL触发器当服务器或者数据中发送数据定义语言(DDL)事件时将被调用。如果执行以下操作
,可以使用DDL触发器。
要防止对数据库架构进行某些更改。
希望数据库中发生某种情况以响应数据库架构中的更改。
要记录数据库架构中的更改或事件。
DML触发器
DML触发器是当数据库服务器中发生数据操作语言(DML)事件时要执行的操作。通常所说的DML
触发器主要包括三种:insert触发器,update触发器,delete触发器。DML触发器可以查询其
他表,还可以包含复杂的T_SQL语句。将触发器和触发它的语句作为可在触发器内回滚的单个
事务对待。如果检查到错误,则整个事务自动回滚。
创建insert触发器
语法格式:
create trigger trigger_name
on{table | view}
{
{
{for | after | instead of}
{[delete][,][insert][,][update]}
as
sql_statement
}
}
例子:
create trigger T_addnum
on 学生信息
for insert
as
update 班级信息 set 班级人数 = 班级人数 + 1
where 班级编号 = (select 所属班级 from inserted)
创建delete触发器
create trigger T_delete
on 教师信息
for delete
as
select * from deleted
创建update触发器
create trigger T_update
on 教师信息
for update
as
if(update(姓名) or (性别))
begin
print '事务不能被处理,基础数据不能修改'
rollback transaction
end
else
begin
print '数据修改成功'
end
创建DDL触发器
语法格式:
create trigger trigger_name
on {all server | database}
with encryption
{for|after{event_type}}
as
sql_statement
例子:
create table T_notDelete
on database
for drop_table, alter_table
as
print 'no admission'
rollback
管理触发器
修改触发器:
alter trigger trigger_name
on {all server | database}
with encryption
{for|after{event_type}}
as
sql_statement
禁用触发器
alter table 员工信息
disable trigger t_add
启用触发器
alter table 员工信息
enable trigger t_add
删除触发器
drop trigger t_add
嵌套触发器
create trigger t_add
on 员工信息
for inserte
as
update 部门信息 set 部门人数 = 部门人数 + 1
where 部门编号 = (select 所在部门编号 from inserted)
create trigger t_delete
on 新员工信息
for delete
as
insert into 员工信息(员工编号, 员工姓名, 所在部门编号, 所任职位, 性别)
select 员工编号, 员工姓名, 所在部门编号, 所任职位, 性别
from deleted
递归触发器
任何触发器都可以包含影响同一个表或另一个表的update,insert或delete语句。如果启用递
归触发器选项,那么改变表中数据的触发器,通过递归执行就可以再次出发自己。在数据库
创建时,默认情况下递归触发器选项时禁用的,但可以使用alter database语句来启用它。
递归触发器具有复杂特性,可以用它来解决诸如自引用这样的复杂关系。使用递归触发器时,
需要考虑以下的事项和原则:
递归触发器很复杂,必须经过有条理的设计和全面的测试。
在任意点的数据修改会触发一系列触发器。尽管提供处理复杂关系的能力,但是如果表要
求以特定的顺序更新用户的表时,使用递归触发器就会产生问题。
所有触发器一起构成一个大事件。任何触发器中的任何位置上的rollback命令都将取消
所有数据输入。所有数据均被擦除,并且无任何数据将被放到表中。
触发器最多只能递归16层。换句话说,如果递归链中的第16个触发器激活了第17个触发器
则结果与发布rollback命令一样,所有数据被擦除。
-
SQL触发器(学生表,授课表,选课表)
2016-11-26 13:29:47当对某一表进行诸如UPDATE、INSERT、DELETE这些操作时,SQLSERVER就会自动执行触发器所定义的SQL语句 ,从而确保对数据的处理必须符合这些SQL语句所定义的规则。 表创建: 学生表: 授课表(教师表-课程表): ...存储器和触发器区别:
触发器主要是通过事件执行触发而被执行的,而存储过程可以通过存储过程名称名字而直接调用。
当对某一表进行诸如UPDATE、INSERT、DELETE这些操作时,SQLSERVER就会自动执行触发器所定义的SQL语句
,从而确保对数据的处理必须符合这些SQL语句所定义的规则。
表创建:
学生表:
授课表(教师表-课程表):
选课表:
在这里注意选课表是不需要添加外键约束的,而是用触发器来实现数据库完整性。
触发器设置:
1.当向选课表中插入数据时,检查该行的学号列在学生表中是否存在,授课号列在授课表中是否存在,
如有一项不成立,则不允许插入,并显示存错信息“学生表没有该学号信息或授课表没有该课程号,请仔细检查”
备注: 1.raiserror 函数用于返回用户定义的错误信息并设置系统标志。第2个参数是错误的严重级别;第3个参数表示有关
错误调用状态的信息. 2.rollback表示回滚,不允许插入新行
2.我们可以这样设想,当某个学生退学不读书了,那么他在选修表中的信息也应该被删除.现创建一个触发器,名为"Delete_sc".
如果要删除学生表中的记录,则与该记录学号对应的选修表中的选修记录也一起删除.
插入一条学生信息
插入该学生的选课信息
现在假设学号为S004的学生退学了,在Students表中删除该学生所有信息
在选课表中该学生的选课记录也随学生表信息删除随之删除
触发器的查看:
--用于查看触发器的一般信息。
sp_help [触发器名称]--用于显示存储过程的源代码
sp_helptext [触发器名称]--用于查看指定触发器所引用的表或者指定的表涉及的所有触发器。格式如下:
sp_depends [触发器名称]
sp_depends [表名]修改触发器:
使用 alter trigger命令修改触发器
例:把触发器Delete_sc 修改为当删除课程表中的记录时,显示"记录已被删除,触发器起到作用"注:alter trigger的触发器必须先create,不能alter一个不存在的触发器
重命名触发器
--把触发器 Delete_sc 重命名为"Delete_ssc"
sp_rename Delete_sc,Delete_ssc
删除触发器
--删除触发器"Delete_ssc" drop trigger Delete_ssc
-
什么是触发器?mysql 触发器如何设置
2020-12-06 10:24:26当对某一表进行诸如UPDATE、 INSERT、 DELETE 这些操作时,mysql 就会自动执行触发器所定义的SQL 语句,从而确保对数据的处理必须符合由这些SQL 语句所定义的规则。 例:一张部门表dep 员工表em 更改dep的id时,...概念
当对某一表进行诸如UPDATE、 INSERT、 DELETE 这些操作时,mysql 就会自动执行触发器所定义的SQL 语句,从而确保对数据的处理必须符合由这些SQL 语句所定义的规则。
例:一张部门表dep 员工表em 更改dep的id时,同时修改em所对应的dep_id
dpe表id字段创建触发器,
推荐阅读:《mysql常用函数,mysql进阶》
-
数据库(十)之触发器
2019-09-21 12:58:55触发器什么是触发器?触发器是一个在修改表中的数据时执行的存储过程。通常通过创建触发器来实现不同表中的逻辑相关数据的引用完整性或一致性。由于用户不能绕过触发器,...当对某一表进行诸如update,insert,dele...转载于:https://www.cnblogs.com/ZGreMount/p/8612304.html
-
SQL Server之触发器
2019-08-19 08:46:00第十章 触发器 概念;触发器是一个在修改指定表中的数据时执行的存储过程,经常通过创建触发器来强制实现不同表中的逻辑相关数据的引用完整性或 一致性。由于用户不能绕过触发器...当对某一表进行诸如update,inder...第十章 触发器 概念;触发器是一个在修改指定表中的数据时执行的存储过程,经常通过创建触发器来强制实现不同表中的逻辑相关数据的引用完整性或 一致性。由于用户不能绕过触发器,所以可以用它来强制实施复杂的业务规则,以此确保数据的完整性。
使用:触发器不同于我们前面介绍的存储过程。触发器主要是通过事件进行触发而被执行的,而存储过程可以通过存储过程名字而直接被调用。当对某一表进行诸如update,indert,delete这些操作时,sql server就会自动执行触发器所定义的sql语句,从而确保对数据的处理必须符合这些sql语句所定义的规则。
使用触发器优点1.触发器自动执行,它们在表的数据做了任何修改后(比如手工输入或使用程序采集操作)之后立即激活。
2.触发器可以通过数据库中的相关表进行层叠更改。这比直接把代码写在前台的做法安全合理。
3.触发器可以强制限制,这些限制比check约束所定义的更复杂。与check约束不同的是,触发器可以引用其他表中的列。触发器的种类
DDL触发器:DDL触发器当服务器或者数据库中发生数据定义语言(DDL)事件时将被调用。
DML触发器:DML触发器是当数据库服务器中发生数据操作语言(DML)事件时要执行的操作。包括三种:INSERT触发器,DELETE触发器,UPDATE 触发器insert触发器的使用:实现当学生人数增加1,班级人数+1
create trigger T_addnum on 学生信息1 for insert as update 班级信息 set 班级人数=班级人数+1 where 班级编号=(select 所属班级 from 学生信息1)
delete触发器的使用
create trigger T_DELETETRACHER on 学生信息1 for delete as select 姓名 as 被删除的学生姓名,性别,民族 from deleted delete from 学生信息1 where 学号='3'
update触发器的使用
把学生的姓名看成时基础信息不可以修改,修改时弹出提示框‘事务不能被处理,基础数据不能修改!’,并且回滚事务,如果修改民族等信息,就提示事务修改成功。create trigger T_UPDATE on 学生信息1 for update as if update(姓名) begin print '事务不能被处理,基础数据不能修改!‘ end else print'数据修改成功!' update 学生信息1 set 民族='傣族' where 学号='5'
执行结果如下:
创建DDL触发器create trigger T_notedelete on database for drop_table,alter_table as print '事务不能被处理,基础数据表不能被修改和删除!' rollback
管理触发器:修改,删除,启动和禁用触发器
删除触发器: drop trigger trigger_name
禁用触发器:
alter table table_name(在哪个表上创建的触发器)
Disable trigger trigger_name
启动触发器:
alter table table_name(在哪个表上创建的触发器)
enable trigger trigger_name触发器递归
任何触发器都可以包含影响同一个或另一个表的update,insert或delete语句,如果启用递归触发器选项,那么改变表中数据的触发器,通过递归执行可以再次触发自己。在数据库创建时,默认情况下递归触发器选项是禁用的,但可以使用alter database 语句来启用它。
-
数据库视频第十章触发器
2021-02-08 19:06:521.什么是触发器 触发器是一个在修改指定表中的数据时执行的存储过程。...当对某一表进行诸如UPDATE、INSERT、 DELETE这些操作时,SQLServer就会自动执行触发器所定义的SQL语句,从而确保对数据的处理必须符合由这些SQ -
触发器
2017-06-26 16:44:00当对某一表进行诸如Update、 Insert、 Delete 这些操作时,SQL Server 就会自动执行触发器所定义的SQL 语句,从而确保对数据的处理必须符合由这些SQL 语句所定义的规则。 触发器的主要作用就是其能够实... -
什么是SQL触发器?SQL触发器是什么意思?
2016-04-22 10:40:49什么是SQL触发器?SQL触发器是什么意思?...当对某一表进行诸如UPDATE、 INSERT、 DELETE 这些操作时,SQL Server 就会自动执行触发器所定义的SQL 语句,从而确保对数据的处理必须符合由这些SQL 语句所定义的规 -
存储过程和触发器的区别
2017-09-15 21:23:23存储过程,你调用的时候才会执行 触发器就是你设定了...当对某一表进行诸如UPDATE、INSERT、DELETE这些操作时,SQLSERVER就会自动执行触发器所定义的SQL语句,从而确保对数据的处理必须符合这些SQL语句所定义的 -
【MySql学习系列】触发器
2013-10-25 15:26:33本文讲述MySql5.x中触发器的使用,包括创建触发器、删除触发器和查询触发器的相关知识,对其语法、使用...当对某一表进行诸如UPDATE、 INSERT、 DELETE 这些操作时,就会自动执行触发器所定义的SQL 语句。 触发器... -
触发器的如何使用
2020-05-19 11:35:38当对某一表进行诸如UPDATE、 INSERT、 DELETE 这些操作时,SQL Server 就会自动执行触发器所定义的SQL 语句,从而确保对数据的处理必须符合由这些SQL 语句所定义的规则。 1.触发器的主要作用就是其能够实现由主键和... -
触发器与存储过程的区别
2015-10-13 12:55:30触发器原理: 触发器与存储过程非常相似,触发器也是SQL语句集,两者唯一的区别是触发器不能用EXECUTE语句调用,而是在用户执行Transact-SQL语句时...当对某一表进行诸如UPDATE、INSERT、DELETE这些操作时,SQLSERVE -
SQL_Server_2008完全学习之第十章触发器
2013-08-29 14:40:00- 1、什么时触发器?1)触发器是一个在修改指定表中的数据时执行的存储过程。经常通过创建触发器来强制实现不同表中的逻辑相关数据的引用完整性或一致性。...当对某一表进行诸如:UDPATE、IN... -
Oracle数据库中有关触发器问题
2013-01-14 09:46:37Oracle数据库中有关触发器问题 触发器是一种特殊类型的存储过程,它不同于存储过程。触发器主要是通过事件...当对某一表进行诸如UPDATE、 INSERT、 DELETE 这些操作时,SQL Server 就会自动执行触发器所定义的SQL ... -
oracle触发器的编写
2011-03-23 20:49:49当对某一表进行诸如UPDATE、 INSERT、 DELETE 这些操作时,ORACLE 就会自动执行触发器所定义的SQL 语句,从而确保对数据的处理必须符合由这些SQL 语句所定义的规则。 ORACLE中简单的触发器定义如下: [b]1 对于表... -
触发器的概念及作用
2012-10-25 09:18:14当对某一表进行诸如Update、 Insert、 Delete 这些操作时,SQL Server 就会自动执行触发器所定义的SQL 语句,从而确保对数据的处理必须符合由这些SQL 语句所定义的规则。 触发器的主要作用就是其能够实现由主键... -
触发器学习笔记
2011-04-29 12:27:00触发器学习概念:触发器是一种特殊的存储过程,MySQL5.0以上版本支持触发器,触发器是与表有关的...当对某一表进行诸如UPDATE、 INSERT、 DELETE 这些操作时,就会自动执行触发器所定义的SQL 语句。权限说明:激活... -
数据库 Trigger
2011-12-25 10:58:18什么是触发器(Trigger)? 触发器是一种特殊类型的存储过程,它不同于存储过程。...当对某一表进行诸如UPDATE、 INSERT、 DELETE 这些操作时,SQL Server 就会自动执行触发器所定义的SQL 语句,从而确保对数据的处 -
什么是SQL触发器
2009-05-04 20:51:00当对某一表进行诸如UPDATE、 INSERT、 DELETE 这些操作时,SQL Server 就会自动执行触发器所定义的SQL 语句,从而确保对数据的处理必须符合由这些SQL 语句所定义的规则。 触发器的种类SQL Server -
谈谈数据库触发器
2009-05-29 22:30:24[color=blue]触发器介绍 ...当对某一表进行诸如UPDATE、 INSERT、 DELETE 这些操作时,SQL Server 就会自动执行触发器所定义的SQL 语句,从而确保对数据的处理必须符合由这些SQL 语句所定义的规则。... -
数据库触发器
2009-03-24 20:32:47当对某一表进行诸如UPDATE、 INSERT、 DELETE 这些操作时,SQL Server 就会自动执行触发器所定义的SQL 语句,从而确保对数据的处理必须符合由这些SQL 语句所定义的规则。 触发器的主要作用就是... -
SQL 2000触发器原理[软创09年java笔试题]
2009-02-22 14:57:00当对某一表进行诸如Update、 Insert、 Delete 这些操作时,SQL Server 就会自动执行触发器所定义的SQL 语句,从而确保对数据的处理必须符合由这些SQL 语句所定义的规则。触发器的主要作用就是其能够实现由主键和外键... -
SQL 触发器
2008-07-04 12:19:00当对某一表进行诸如Update、 Insert、 Delete 这些操作时,SQL Server 就会自动执行触发器所定义的SQL 语句,从而确保对数据的处理必须符合由这些SQL 语句所定义的规则。 触发器的主要作用就是其能够