数据库视频总结(七)——触发器

概述

概念:
触发器是一个在修改指定表中的数据时执行的存储过程。经常通过创建触发器来强制实现不同表中的逻辑相关数据的引用完整性或一致性。由于用户不能绕过触发器,所以可用它来强制实施复杂的业务规则,以此确保数据的完整性。

优点:
1、自动执行
2、可以通过数据库中的相关表进行层叠更改
3、可以强制限制,比用CHECK约束所定义的更复杂,触发器可以引用其他列表中的列

分类

主要分为DDL和DML两大类
DDL:
该触发器当服务器或者数据库中发生数据定义语言(ddl)事件时将被调用。如果要执行以下操作,可以使用DDL触发器
1、要防止对数据库架构进行某些更改
2、希望将数据库中发生某种情况以响应数据库架构中的更改
3、要记录数据库架构中的更改或者事件
DML:
该触发器是当数据库服务器中发生数据操作语言(dml)事件时要执行的操作。通常所说的DML触发器主要包括三种:INSERT触发器、UPDATE触发器、DELETE触发器、DML触发器可以查询其他表,还可以包含发咋的sql语句

创建INSERT触发器

语法格式:
CREATE TRIGGER trigger_name
On+表或者视图
{
    For\after\instead of
    Delete,insert,update
    As
    Sql_statement
}
举例:
select 班级人数 from 班级信息 where 班级编号='101'
insert into 学生信息 values('1258963','王俊','女','1986-01-16','101','河北省廊坊市安次区')
select 班级人数 from 班级信息 where 班级编号='101'

效果如下:
这里写图片描述

创建DELETE触发器

举例:
创建触发器
Create trigger t_deleteteacher
On 教师信息
For delete
As
    Select 姓名 as 被删除的教师姓名,性别,年龄,联系电话 from deleted
触发:
Delete from 教师信息 where 教师编号='2005001'

效果如下:
这里写图片描述

update触发器:

创建
create trigger t_update 
on 教师信息
for update 
as
if(update(姓名)or update(性别))
begin 
    print'事务不能被处理,基础数据不能修改!'
    rollback transaction
end
else
    print'数据修改成功!'

执行:
Update 教师信息 set 姓名='李芳' where 教师编号='20020010'
Select * from 教师信息
输出:
事务不能被处理,基础数据不能修改、
执行:
Update 教师信息 set 联系电话='123456789454'  where 教师编号='20050010'
输出:
数据修改成功

创建DDL触发器

**语法格式:**
Create trigger trigger_name
On  all server|detabase
With encryption(是否加密)
For |after{event_type}
As
Sql_statement

举例:
create trigger t_notdelete
on database 
for drop_table,alter_table
as
    print'事务不能被处理,基础数据表不能被修改和删除!'
    rollback

管理触发器
禁用:
发一:直接右击禁用
发二:用sql 语句:
Alter table 员工信息
Disable trigger t_add
启用同上:
删除:
1、右击删除
2、Drop trigger t_add

递归触发器

这里写图片描述
使用递归触发器需要考虑以下的事项和原则
1、递归触发器很复杂,必须经过有条理的设计和全面的测试
2、用户要求以特定的顺序更新用户的表时,使用递归触发器就会产生问题
3、所有触发器一起构成一个大事务。任何触发器中的任何位置上的ROLLBACK命令都将取消所有数据输入,所有数据均被擦除,并且无任何数据将被放到表中
4、触发器最多只能递归16层,

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值