最近学习触发器,感觉它是个不错的东西,在网上找到触发器的作用,具体如下:
触发器是一种特殊的存储过程,它在插入,删除或修改特定表中的数据时触发执行,它比数据库本身标准的功能有更精细和更复杂的数据控制能力。数据库触发器有以下的作用:
* 安全性。可以基于数据库的值使用户具有操作数据库的某种权利。
# 可以基于时间限制用户的操作,例如不允许下班后和节假日修改数据库数据。
# 可以基于数据库中的数据限制用户的操作,例如不允许股票的价格的升幅一次超过10%。
* 审计。可以跟踪用户对数据库的操作。
# 审计用户操作数据库的语句。
# 把用户对数据库的更新写入审计表。
* 实现复杂的数据完整性规则。 # 实现非标准的数据完整性检查和约束。触发器可产生比规则更为复杂的限制。与规则不同,触发器可以引用列或数据库对象。例如,触发器可回退任何企图吃进超过自己保证金的期货。
# 提供可变的缺省值。
* 实现复杂的非标准的数据库相关完整性规则。触发器可以对数据库中相关的表进行连环更新。例如,在auths表author_code列上的删除触发器可导致相应删除在其它表中的与之匹配的行。
# 在修改或删除时级联修改或删除其它表中的与之匹配的行。
# 在修改或删除时把其它表中的与之匹配的行设成NULL值。
# 在修改或删除时把其它表中的与之匹配的行级联设成缺省值。 # 触发器能够拒绝或回退那些破坏相关完整性的变化,取消试图进行数据更新的事务。当插入一个与其主健不匹配的外部键时,这种触发器会起作用。例如,可以在books.author_code
列上生成一个插入触发器,如果新值与auths.author_code列中的某值不匹配时,插入被回退。
* 同步实时地复制表中的数据。
* 自动计算数据值,如果数据的值达到了一定的要求,则进行特定的处理。例如,如果公司的帐号上的资金低于5万元则立即给财务人员发送警告数据。我的感觉触发器在保证数据的完整性,做的很好,在数据库中是不可缺失的很重要的角色.因为公司的数据库经历了很长时间发展,结构很混乱,数据让人找不到北,把人搞的很心烦,学了触发器之后,想用触发器对现有的数据设计进行重构,可是同事说触发器不是好东西,最好不要用,很烦恼.请各位大哥指教,是多用呢,还是少用?有人说少用,有人说不用?请大家多参与讨论!
触发器是一种特殊的存储过程,它在插入,删除或修改特定表中的数据时触发执行,它比数据库本身标准的功能有更精细和更复杂的数据控制能力。数据库触发器有以下的作用:
* 安全性。可以基于数据库的值使用户具有操作数据库的某种权利。
# 可以基于时间限制用户的操作,例如不允许下班后和节假日修改数据库数据。
# 可以基于数据库中的数据限制用户的操作,例如不允许股票的价格的升幅一次超过10%。
* 审计。可以跟踪用户对数据库的操作。
# 审计用户操作数据库的语句。
# 把用户对数据库的更新写入审计表。
* 实现复杂的数据完整性规则。 # 实现非标准的数据完整性检查和约束。触发器可产生比规则更为复杂的限制。与规则不同,触发器可以引用列或数据库对象。例如,触发器可回退任何企图吃进超过自己保证金的期货。
# 提供可变的缺省值。
* 实现复杂的非标准的数据库相关完整性规则。触发器可以对数据库中相关的表进行连环更新。例如,在auths表author_code列上的删除触发器可导致相应删除在其它表中的与之匹配的行。
# 在修改或删除时级联修改或删除其它表中的与之匹配的行。
# 在修改或删除时把其它表中的与之匹配的行设成NULL值。
# 在修改或删除时把其它表中的与之匹配的行级联设成缺省值。 # 触发器能够拒绝或回退那些破坏相关完整性的变化,取消试图进行数据更新的事务。当插入一个与其主健不匹配的外部键时,这种触发器会起作用。例如,可以在books.author_code
列上生成一个插入触发器,如果新值与auths.author_code列中的某值不匹配时,插入被回退。
* 同步实时地复制表中的数据。
* 自动计算数据值,如果数据的值达到了一定的要求,则进行特定的处理。例如,如果公司的帐号上的资金低于5万元则立即给财务人员发送警告数据。我的感觉触发器在保证数据的完整性,做的很好,在数据库中是不可缺失的很重要的角色.因为公司的数据库经历了很长时间发展,结构很混乱,数据让人找不到北,把人搞的很心烦,学了触发器之后,想用触发器对现有的数据设计进行重构,可是同事说触发器不是好东西,最好不要用,很烦恼.请各位大哥指教,是多用呢,还是少用?有人说少用,有人说不用?请大家多参与讨论!
解决方案 »
- RMB 200元 odac 连接oracle 9i 汉字字段名乱码
- Ubuntu下安装Oracle
- 我重装了XP SP3,默认系统字体是微软雅黑,用PLSQL的时候匹配不到中文数据了
- 怎么把access数据库表中某列的值求和?
- 一个很搞笑的文章!!!!
- trigger自动更新问题
- 关于一个EXISTS的问题....在线等!
- alter table add column改变增加列的位置顺序
- 这个触发器要怎么写呀!!(sqlserver->oracle)在线等!!!
- 100分求教oracle9i安装在win2003上出现12541-TNS没有监听器错误。
- 把Oracle转换成SQLServer
- 一个关于索引的问题!
trigger没有问题,关键是如何用.唯一的建议就是不要用的太多,这个应该是系统架构之类的人考虑的.
最后,看具体情况.
能用数据库处理的东西,不用程序来处理,但是触发器也不要用的太多,会造成系统性能的下降!