- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
步骤2:验证运行结果: INSERT INTO emp(empno,ename,job,sal) VALUES(1000,BILL,CLERK,1500); 执行结果: 已创建 1 行。 执行查询: SELECT ename,job,sal FROM emp WHERE empno=1000; 执行结果: ENAME JOB SAL ------------- ------------- ------------------------ Bill CLERK 1500 说明:在本例中,通过直接为:new.ename进行赋值,修改了插入的值,但是这种用法只能在BEFORE型触发器中使用。验证结果为,在插入语句中雇员名称为大写的BILL,查询结果中雇员名称已经转换成以大写开头的Bill。 【练习5】限定一次对雇员的工资修改不超过原工资的10%。 语句级触发器的应用 同行级触发器不同,语句级触发器的每个操作语句不管操作的行数是多少,只触发一次触发器,所以语句级触发器适合于对整个表的操作权限等进行控制。在触发器定义中若省略FOR EACH ROW子句,则为语句级触发器。 【训练1】 创建一个语句级触发器CHECK_TIME,限定对表EMP的修改时间为周一至周五的早8点至晚5点。 步骤1:创建和编译以下触发器: CREATE OR REPLACE TRIGGER CHECK_TIME BEFORE UPDATE OR INSERT OR DELETE ON EMP BEGIN IF (TO_CHAR(SYSDATE,DY) IN (SAT,SUN)) OR TO_CHAR(SYSDATE,HH24) 08 OR TO_CHAR(SYSDATE,HH24)=17 THEN RAISE_APPLICATION_ERROR(-20500,非法时间修改表错误!); END IF; END; 执行结果: 触发器已创建。 步骤2:当前时间为18点50分,在EMP表中插入记录: UPDATE EMP SET SAL=3000 WHERE EMPNO=7369; 显示结果为: UPDATE EMP SET SAL=3000 WHERE EMPNO=7369 * ERROR 位于第 1 行: ORA-20500: 非法时间修改表错误! ORA-06512: 在STUDENT.CHECK_TIME, line 5 ORA-04088: 触发器 ‘STUDENT.CHECK_TIME’ 执行过程中出错 说明:通过引发异常限制对数据库进行的插入、删除和修改操作的时间。SYSDATE用来获取系统当前时间,并按不同的格式字符串进行转换。“DY”表示获取英文表示的星期简写,“HH24”表示获取24小时制时间的小时。 当在18点50分修改表中的数据时,由于时间在8点至17点(晚5点)之外,所以产生“非法时间修改表错误”的用户自定义错误,修改操作终止。 【练习1】设计一个语句级触发器,限定只能对数据库进行修改操作,不能对数据库进行插入和删除操作。 2 替代触发器 替代触发器是DML触发器的一种,替代条件换成instead of,而不是before和after,其他内容跟dml一致。并且替代触发器一般建立在不可更新的视图上,可以实现对不可更新视图的更新操作替换成对表的直接操作。 【训练1】 在emp表的视图上,通过触发器修改emp表。 步骤1:创建视图emp_name: CREATE VIEW emp_name AS SELECT ename FROM emp; 执行结果: 视图已建立。 步骤1:创建替代触发器: CREATE OR REPLACE TRIGGER change_name INSTEAD OF INSERT ON emp_name DECLARE V_EMPNO NUMBER(4); BEGIN SELECT MAX(EMPNO)+1 INTO V_EMPNO FROM EMP; INSERT INTO emp(empno,ename) VALUES(V_EMPNO,:new.ename); END; 执行结果: 触发器已创建。 步骤2:向emp_name视图插入记录: INSERT INTO emp_name VALUES(BROWN); COMMIT; 执行结果: 已创建 1 行。 提交完成。 ?说明:向视图直接插入雇员名将会发生错误,因为emp表的雇员编号列不允许为空。通过创建替代触发器,将向视图插入雇员名称转换为向emp表插入雇员编号和雇员名称,雇员编号取当前的最大雇员编号加1。试检查emp表的雇员列表。 触发器体内禁止使用COMMIT、RO
您可能关注的文档
最近下载
- 领读经典-外国文学(1)(山东大学)中国大学MOOC慕课 章节测验期末考试客观题答案.docx VIP
- 《电机与拖动基础》课件(共十一章).ppt VIP
- 《PyTorch与深度学习实战》第2章 PyTorch深度学习通用流程.pptx VIP
- 简谱D 想着我Think of Me简谱歌剧魅影.pdf VIP
- 2023-2024学年安徽省马鞍山市第八中学九年级上学期期中考试化学试卷.pdf VIP
- 《PyTorch与深度学习实战》第3章 PyTorch深度学习基础.pptx VIP
- 好书推荐《朝花夕拾》读书分享名著导读PPT课件.pptx VIP
- 22个专业95个病种中医临床诊疗方案目录44.pdf VIP
- 精品解析:天津市第四十三中学2024-2025学年高一上学期第一次月考英语试题(解析版).docx VIP
- 2025年北京市东城区九年级初三一模语文试卷(含答案).docx
文档评论(0)