- 1、本文档共11页,可阅读全部内容。
- 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
触发器语法详解触发语法详解
Oracle 触发器语法
关键字: oracle 触发器语法
一 Oracle触发器语法
触发器是特定事件出现的时候,自动执行的代码块。类似于存储过程,触发器与存储过程的区别在于:存储过程是由用户或应用程序显式调用的,而触发器是不能被直接调用的。
功能:
1、 允许/限制对表的修改
2、 自动生成派生列,比如自增字段
3、 强制数据一致性
4、 提供审计和日志记录
5、 防止无效的事务处理
6、 启用复杂的业务逻辑
触发器触发时间有两种:after和before。
1、触发器的语法:
CREATE [OR REPLACE] TIGGER触发器名 触发时间 触发事件
ON表名
[FOR EACH ROW]
BEGIN
pl/sql语句
END
其中:
触发器名:触发器对象的名称。
由于触发器是数据库自动执行的,因此该名称只是一个名称,没有实质的用途。
触发时间:指明触发器何时执行,该值可取:
before---表示在数据库动作之前触发器执行;
after---表示在数据库动作之后出发器执行。
触发事件:指明哪些数据库动作会触发此触器:????????????????????????
insert:数据库插入会触发此触发器;????
update:数据库修改会触发此触发器;
delete:数据库删除会触发此触发器。
表 名:数据库触发器所在的表。
for each row:对表的每一行触发器执行一次。如果没有这一选项,则只对整个表执行一次。
2、举例:
下面的触发器在更新表auths之前触发,目的是不允许在周末修改表:
??????create?triggerauth_secure?before?insert?or?update?or?delete?//对整表更新前触发 on?auths begin if(to_char(sysdate,DY)=SUN RAISE_APPLICATION_ERROR(-20600,不能在周末修改表auths); end?if; end 例子:
?? CREATE?OR?REPLACE?TRIGGER?CRM.T_SUB_USERINFO_AUR_NAME?AFTER?UPDATE?OF?STAFF_NAME ON?CRM.T_SUB_USERINFO REFERENCING?OLD?AS?OLD?NEW?AS?NEW FOR?EACH?ROW declare begin if?:NEW.STAFF_NAME!=:OLD.STAFF_NAME?then begin 客户投诉
? update?T_COMPLAINT_MANAGE?set?SERVE_NAME=:NEW.STAFF_NAME?where?SERVE_SEED=:OLD.SEED; 客户关怀
????? update?T_CUSTOMER_CARE?set?EXECUTOR_NAME=:NEW.STAFF_NAME where?EXECUTOR_SEED=:OLD.SEED; 客户服务
??????update?T_CUSTOMER_SERVICE?set?EXECUTOR_NAME=:NEW.STAFF_NAME where?EXECUTOR_SEED=:OLD.SEED; end; end?if; end?T_sub_userinfo_aur_name; / ?
二 Oracle触发器详解
开始:
????? create?triggerbiufer_employees_department_id beforeinsertorupdateofdepartment_idonemployees referencingoldasold_value?newasnew_value for?each?row when?(new_value.department_id80?) begin :new_mission_pct?:=0; end; / 1、触发器的组成部分:
1、 触发器名称
2、 触发语句
3、 触发器限制
4、 触发操作
1.1、触发器名称
????? create?trigger?biufer_employees_department_id 命名习惯:
????? biufer(before?insert?update?for?each?row) e
您可能关注的文档
- 西方行政学说史西方政学说史.doc
- 西方翻译思想流派1.doc
- 西方行政学说试题答案.doc
- 西方语言学流派西方言学流派.doc
- 西村·贝森大院项目述综述.doc
- 西方音乐鉴赏论文西音乐鉴赏论文.doc
- 西校村书记述职报告.doc
- 西格蒙德·弗洛伊德.doc
- 西安旅游导游词西安游导游词.doc
- 西游记_趣味答题1.doc
- 金融产品2024年投资策略报告:积极适应市场风格,行为金融+机器学习新发现.pdf
- 交运物流2024年度投资策略:转型十字路,峰回路又转(2023120317).pdf
- 建材行业2024年投资策略报告:板块持续磨底,重点关注需求侧复苏.pdf
- 宏观2024年投资策略报告:复苏之路.pdf
- 光储氢2024年投资策略报告:复苏在春季,需求的非线性增长曙光初现.pdf
- 公用环保2024年投资策略报告:电改持续推进,火电盈利稳定性有望进一步提升.pdf
- 房地产2024年投资策略报告:聚焦三大工程,静待需求修复.pdf
- 保险2024年投资策略报告:资产负债匹配穿越利率周期.pdf
- 政策研究2024年宏观政策与经济形势展望:共识与分歧.pdf
- 有色金属行业2024年投资策略报告:新旧需求共振&工业原料受限,构筑有色大海星辰.pdf
文档评论(0)