本文收集整理关于数据库触发器怎么用的相关议题,使用内容导航快速到达。
内容导航:
Q1:数据库触发器有什么作用?
触发器的作用:
自动计算数据值,如果数据的值达到了一定的要求,则进行特定的处理。
同步实时地复制表中的数据。
实现复杂的非标准的数据库相关完整性规则。
可在写入数据表前,强制检验或转换数据。
触发器发生错误时,异动的结果会被撤销。
部分数据库管理系统可以针对数据定义语言(DDL)使用触发器,称为DDL触发器。
可依照特定的情况,替换异动的指令 (INSTEAD OF)。
扩展资料:
分类
SQL Server 包括三种常规类型的触发器:DML 触发器、DDL 触发器和登录触发器。
DML触发器
当数据库中表中的数据发生变化时,包括insert,update,delete任意操作,如果我们对该表写了对应的DML触发器,那么该触发器自动执行。
DML触发器的主要作用在于强制执行业 务规则,以及扩展Sql Server约束,默认值等。因为我们知道约束只能约束同一个表中的数据,而触发器中则可以执行任意Sql命令。
DDL触发器
它是Sql Server2005新增的触发器,主要用于审核与规范对数据库中表,触发器,视图等结构上的操作。比如在修改表,修改列,新增表,新增列等。
它在数据库结构发生变化时执行,我们主要用它来记录数据库的修改过程,以及限制程序员对数据库的修改,比如不允许删除某些指定表等。
登录触发器
登录触发器将为响应 LOGIN 事件而激发存储过程。与 SQL Server 实例建立用户会话时将引发此事件。登录触发器将在登录的身份验证阶段完成之后且用户会话实际建立之前激发。
因此,来自触发器内部且通常将到达用户的所有消息(例如错误消息和来自 PRINT 语句的消息)会传送到 SQL Server 错误日志。如果身份验证失败,将不激发登录触发器。
Q2:.NET 数据库触发器怎么用?
create trigger Album_delete on Album --为Album表创建触发器
for delete --触发事件为delete
as
begin
delete from Photos where AlbumID=(select AlbumID from deleted) --删除Photos表里AlbumID 等于Album里正在删除的ID的内容
end
--deleted是系统内置的,例如插入就是:inserted
--修改就是:updated
现在你去删除一个相册,这个相册里的照片就会删除了
Q3:mysql数据库触发器,怎么做满足条件触发
语法错误。
MySQL 里面。
IF 条件 THEN
......
END IF
的。
例如:
1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950mysql>DELIMITER//mysql>CREATEPROCEDURETestIfElse->(->p_valINT->)->BEGIN->IF(p_val=1)THEN->SELECT1ASA;->ELSEIF(p_val=2)THEN->SELECT2ASA;->ELSE->SELECTotherASA;->ENDIF;->END//QueryOK,0rowsaffected(0.05sec)mysql>callTestIfElse(1);->//+---+|A|+---+|1|+---+1rowinset(0.00sec)QueryOK,0rowsaffected(0.00sec)mysql>callTestIfElse(2);->//+---+|A|+---+|2|+---+1rowinset(0.00sec)QueryOK,0rowsaffected(0.00sec)mysql>callTestIfElse(3);->//+-------+|A|+-------+|other|+-------+1rowinset(0.00sec)QueryOK,0rowsaffected(0.00sec)mysql>你那里少了一个 THEN
Q4:数据库触发器的优缺点以及用法
触发器本质上讲就是事件监控器,可以定义在数据库系统进行某一个操作的前后。
当数据库系统在进行特定的操作时,发现有触发器定义,就去执行触发器定义的功能,从而满足某些特定的需要。
例如,在更新某些数据后,再去更新特定的数据。
这就可以定义一个触发器完成这样的需要。
触发器的优点:
以事件方式来处理.当数据发生变化的时候, 自动作处理。
缺点:
当数据库之间 导出导入的时候, 可能会引起不必要的触发逻辑。