⑴ sql中触发器怎样执行的
创建触发器 是特殊的存储过程,自动执行,一般不要有返回值。
1、后触发器 (AFTER,FOR)先执行对应语句,后执行触发器中的语句。
2、前触发器 并没有真正的执行触发语句(insert,update,delete),而是执行触发后的语句。
3、行级触发器 (FOR EACH ROW) 在SQL server 中不存在。
(1)数据库中触发器有几种触发条件扩展阅读:
创建触发的语法
CREATE TRIGGER trigger_name --触发器名称
ON table_name --触发的表
[WITH ENCRYPTION]
FOR [DELETE, INSERT, UPDATE] --选择触发器类型
AS --触发后要做的语句
T-SQL语句
GO --结束标记
⑵ sql server2008中的触发器有3种类型,分别为
(1)DML触发器:是指触发器在数据库中发生数据操作语言(DML)事件时将启用。DML事件即指在表或视图中修改数据的insert、update、delete语句也。
(2)DDL触发器:是指当服务器或数据库中发生数据定义语言(DDL)事件时将启用。DDL事件即指在表或索引中的create、alter、drop语句也。
(3)登陆触发器:是指当用户登录SQL SERVER实例建立会话时触发。
⑶ 数据库触发器有什么作用
触发器的作用:
自动计算数据值,如果数据的值达到了一定的要求,则进行特定的处理。
同步实时地复制表中的数据。
实现复杂的非标准的数据库相关完整性规则。
可在写入数据表前,强制检验或转换数据。
触发器发生错误时,异动的结果会被撤销。
部分数据库管理系统可以针对数据定义语言(DDL)使用触发器,称为DDL触发器。
可依照特定的情况,替换异动的指令 (INSTEAD OF)。
(3)数据库中触发器有几种触发条件扩展阅读:
分类
SQL Server 包括三种常规类型的触发器:DML 触发器、DDL 触发器和登录触发器。
DML触发器
当数据库中表中的数据发生变化时,包括insert,update,delete任意操作,如果我们对该表写了对应的DML触发器,那么该触发器自动执行。
DML触发器的主要作用在于强制执行业 务规则,以及扩展Sql Server约束,默认值等。因为我们知道约束只能约束同一个表中的数据,而触发器中则可以执行任意Sql命令。
DDL触发器
它是Sql Server2005新增的触发器,主要用于审核与规范对数据库中表,触发器,视图等结构上的操作。比如在修改表,修改列,新增表,新增列等。
它在数据库结构发生变化时执行,我们主要用它来记录数据库的修改过程,以及限制程序员对数据库的修改,比如不允许删除某些指定表等。
登录触发器
登录触发器将为响应 LOGIN 事件而激发存储过程。与 SQL Server 实例建立用户会话时将引发此事件。登录触发器将在登录的身份验证阶段完成之后且用户会话实际建立之前激发。
因此,来自触发器内部且通常将到达用户的所有消息(例如错误消息和来自 PRINT 语句的消息)会传送到 SQL Server 错误日志。如果身份验证失败,将不激发登录触发器。
参考资料来源:网络-触发器
⑷ oracle中触发器都有几种
DML触发器,又分为行级(for each row)和语句级,
替代触发器,instead of
系统触发器,也叫数据库级,比如startup,shutdown等
用户事件触发器,比如Logon,logoff
⑸ 数据库触发器问题
--成绩表的插入触发器
Create Trigger tri_insert ON stu_grade
for insert
AS
set nocount on
Insert into Stu_info2
Select *
From Stu_info B
Where exists
(
Select 1 From stu_grade A,inserted I where A.学号=I.学号
And A.学号 = B.学号
And A.成绩< 60 Group by A.学号 having count(A.学号) > 4)
)
set nocount off
请参考 sql server 触发器,有问题进一步交流
⑹ 在数据库里怎么使用触发器
触发器是一类特殊的存储过程,开发人员也可以定义、编写符合业务需求的触发器来维护数据的完整性。触发器的控制流程及控制语句与存储过程相同,但触发器与存储过程还是有相当大的差别,触发器的定义格式及开启方式与存储过程不同,作为数据管理员或编程人员,熟练掌握触发器的用法对维护、操作数据库非常重要。基本语法1.创建触发器语法格式创建语法:CREATETRIGGER+触发器名称+触发时间点+触发事件+ON+表名+FOREACHROWBEGIN…END其中,触发时间点:BEFORE或AFTER,指明是在触发事件之前还是之后执行。
触发事件:INSERT、UPDATE、DELETE事件。例如,以下语句创建一个名字叫upd_check的触发器,其在对account表作更新(UPDATE)操作之前(BEFORE)自动触发。
CREATETRIGGERupd_…END2.删除触发器语法格式DROPTRIGGER+触发器名称3.触发器案例用tab.sql脚本创建表环境,然后用下面语句创建触发器。当往tab1表添加记录后将触发此触发器,将此新记录同时插入tab2表中。
DELIMITER//DROPTRIGGERIFEXISTSt_afterinsert_on_tab1;CREATETRIGGERt_afterinsert_on_(tab2_id)values(new.tab1_id);END;//DELIMITER;当用下面语句往tab1表插入记录时,tab2表中同时也添加了同样的记录,如图tab1数据表
tab1数据表
tab2数据表
INSERTINTOtab1(tab1_id)values(')
tab.sql
⑺ 数据库表中的触发器有几种
新增,删除,修改 三种
⑻ mysql数据库触发器,怎么做满足条件触发
语法错误。
MySQL 里面。
IF 条件 THEN
......
END IF
的。
例如:
mysql>DELIMITER//
mysql>CREATEPROCEDURETestIfElse
->(
->p_valINT
->)
->BEGIN
->IF(p_val=1)THEN
->SELECT'1'ASA;
->ELSEIF(p_val=2)THEN
->SELECT'2'ASA;
->ELSE
->SELECT'other'ASA;
->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
⑼ 请列举几种常用的触发器
SQL Server 有三种常规类型的触发器:DML 触发器、DDL 触发器和登录触发器。
DML触发器,当数据库中表中的数据发生变化时,包括insert,update,delete任意操作,如果我们对该表写了对应的DML触发器,那么该触发器自动执行;
DDL触发器,它是Sql Server2005新增的触发器,主要用于审核与规范对数据库中表,触发器,视图等结构上的操作;
登录触发器,登录触发器将为响应 LOGIN 事件而激发存储过程。与 SQL Server 实例建立用户会话时将引发此事件。登录触发器将在登录的身份验证阶段完成之后且用户会话实际建立之前激发。