数据库触发器before和after
2017-12-11 16:43
429 查看
before与after区别:
before:(insert、update)可以对new进行修改,after不能对new进行修改,两者都不能修改old数据。(如果触发器使用after,而定义的触发器调用的函数使用new,就不会执行)
对于insert语句, 只有new是合法的;
对于delete语句,只有old才合法;
对于update语句,new、old可以同时使用。
行级before触发器一般用于检查和修改将被插入和更新的数据;
行级after触发器一般用于将表中被更新的数据记录到其它的表中,或者检查与其它的表中的数据是否是一致的。
before触发器的执行效率比after触发器高,在before触发器和after触发器都能被使用的情况下,应该选择before触发器。
触发器在被调用时,系统会自动传递一些数据给它,这些数据包括触发触发器的事件类型(例如INSERT或UPDATE),对于行级触发器,还包括NEW数据行(对于INSERT和 UPDATE触发器)和OLD数据行(对于UPDATE和DELETE触发器)。每种可以用来书写触发器函数的语言都提供了取这些数据的方法。
语句级别的触发器在执行过程中无法查看该语句插入、删除或更新的任何数据行。
还有一种特殊的触发器叫约束触发器,这种触发器的执行时间可以被命令SET CONSTRAINTS控制。
before:(insert、update)可以对new进行修改,after不能对new进行修改,两者都不能修改old数据。(如果触发器使用after,而定义的触发器调用的函数使用new,就不会执行)
对于insert语句, 只有new是合法的;
对于delete语句,只有old才合法;
对于update语句,new、old可以同时使用。
行级before触发器一般用于检查和修改将被插入和更新的数据;
行级after触发器一般用于将表中被更新的数据记录到其它的表中,或者检查与其它的表中的数据是否是一致的。
before触发器的执行效率比after触发器高,在before触发器和after触发器都能被使用的情况下,应该选择before触发器。
触发器在被调用时,系统会自动传递一些数据给它,这些数据包括触发触发器的事件类型(例如INSERT或UPDATE),对于行级触发器,还包括NEW数据行(对于INSERT和 UPDATE触发器)和OLD数据行(对于UPDATE和DELETE触发器)。每种可以用来书写触发器函数的语言都提供了取这些数据的方法。
语句级别的触发器在执行过程中无法查看该语句插入、删除或更新的任何数据行。
还有一种特殊的触发器叫约束触发器,这种触发器的执行时间可以被命令SET CONSTRAINTS控制。
相关文章推荐
- 数据库中触发器before与after认识
- 数据库中触发器before与after认识
- 数据库中触发器before与after认识
- mysql之触发器before和after的区别(2)
- Oracle中Before和After触发器的例子
- form 触发器的层次Before、Override、after的区别 .
- mysql 触发器after与before的区别
- oracle 触发器before和after数据区别
- form 触发器的层次Before、Override、after的区别
- oracle中触发器中的after和before
- mysql触发器Before和After的区别
- oracle中触发器中的after和before
- 触发器before和after的区别 推荐
- 触发器里 after 和 before的区别
- mysql之触发器before和after的区别
- mysql触发器Before和After的区别
- mysql之触发器before和after的区别
- mysql之触发器before和after的区别
- 24_触发器中的after和before区别
- MySQL触发器 trigger之after与before区分