sqlservertrigger
‘壹’ Oracle中触发器有几种,用法与sql Server一样吗谢谢
ORACLE触发器有以下两类:
1
语句级(Statement-level)触发器,在CREATE
TRIGGER语句中不包含FOR
EACH
ROW子句。语句级触发器对于触发事件只能触发一次,
而且不能访问受触发器影响的每一行的列值。一般用语句级触发器处理有关引起触发器触发的SQL语句的信息——例如,由谁来执行
2
行级(Row-level)触发器,在CREATE
TRIGGER语句中包含FOR
EACH
ROW子句。行级触发器可对受触发器影响的每一行触发,并且能
够访问原列值和通过SQL语句处理的新列值。行级触发器的典型应用是当需要知道行的列值时,执行一条事务规则。
SQL
Server支持两种类型的触发器:
AFTER
触发器和INSTEAD
OF
触发器。其中AFTER
类型触发器要求只有执行某一操作(INSERT
UPDATE
DELETE)
之后,触发器才被触发,且只能在表上定义。可以为针对表的同一操作定义多个触发器。对于AFTER
触发器,可以定义哪一个触发器被最先触发,哪一个被最后触发,通常使用系统过程sp_settriggerorder
来完成此任务。
INSTEAD
OF
触发器表示并不执行其所定义的操作(INSERT、
UPDATE、
DELETE),而仅是执行触发器本身。既可在表上定义INSTEAD
OF
触发器,也可以在视图上定义INSTEAD
OF
触发器,但对同一操作只能定义一个INSTEAD
OF
触发器。
‘贰’ sql server 写一个触发器指定字段更新才触发
createtriggertest
on表一
afterupdate
asbegin
updatebsetb.字段4=a.字段2,b.字段5=a.字段3from表二b,insertedawherea.表一和表二的关联字段=b.表一和表二的关联字段andb.字段5=1
end
点这个地方就能私聊,加一下求求
‘叁’ sqlServer如何在一张表插入数据后马上也会在另一张表中出现
对表1写个添加触发器。createtriggertrigger_1on表1forinsertasdeclare@shuxuedeclare@yuwenselect@shuxue=shuxue,@yuwen=yuwenfrominsertedinsertinto表2values(@shuxue,@yuwen)。
SQL是高级的非过程化编辑语言,允许用户在高层数据结构上工作。它不要求用户指定对数据的存放方法,也不需要用户了解具体的数据存放方式,所以具有完全不同底层结构的不同数据库系统可以使用相同的sql语言作为数据输入与管理的接口。
