oracle期末复习分析和总结.docx

  1. 1、本文档共10页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
实验 12 触发器与作业 姓名: 计算机科学与技术 学号: 0907022128 专业: 网络工程 班级: 09 网络工程同组人: 无 实验日期: 2011-12-5 【实验目的与要求】 ? 理解什么是触发器 ? 掌握触发器的设计与使用 ? 掌握在 Oracle 中完成定时作务的方法 【实验内容与步骤】 相关说明:本实验中前面实验创建的触发器可能对后面的实验产生干扰,若出现这种情况, 请把前面触发器删除,再完成后面实验。建议每完成一个实验题后,即将该题相关的触发器删除,以免对后面实验产生干扰。 触发器创建与删除语法 触发器的创建 触发器是一种在发生数据库事件时自动运行的 PL/SQL 语法如下: CREATE [OR REPLACE] TIGGER 触发器名 触发时间 触发事件 ON 表名 [FOR EACH ROW] BEGIN pl/sql 语句 END 触发器的删除 DROP TRIGGER trigger_name 触发器基础 以下程序展示的是触发器的基本使用方法,请阅读并理解以下程序代码,给出运行结果。 创建测试表 --drop table employees; create table employees( id number(5), name varchar2(30), salary number(8,2), job_id varchar2(20) ); 创建触发器 CREATE OR REPLACE TRIGGER secure_emp_1 --这里不能有 IS BEFORE INSERT ON employees -- 这里没有分号 BEGIN IF (TO_CHAR (SYSDATE,DY) IN (星期六,星期天) OR (TO_CHAR(SYSDATE,HH24:MI) NOT BETWEEN 08:00 AND 18:00 )) THEN RAISE_APPLICATION_ERROR(-20500,你只能在工作时间对表进行操作); END IF; END; / 测试触发器 (1)--测试语句 insert into employees values (1,a,2222,aaaaa); 给出测试结果截图: (2)将系统时间修改为周六,再 Insert 一条记录,给出并比较两次运行的结果。给出测试结果截图: 使用触发器监控数据更新操作 阅读以下程序,理解程序功能,给出运行测试结果。 创建触发器 CREATE OR REPLACE TRIGGER secure_emp_2 BEFORE INSERT OR UPDATE OR DELETE ON employees BEGIN --如果当前时间是周六或周日 或者时间不在 8:00-18:00 之间 IF (TO_CHAR (SYSDATE,DY) IN ( 星 期 五 , 星 期 天 ) OR (TO_CHAR(SYSDATE,HH24:MI) NOT BETWEEN 08:00 AND 18:00 )) THEN IF DELETING THEN RAISE_APPLICATION_ERROR (-20502,你只能在工作时间删除员工表 的数据); 的数据.); 的数据);  ELSIF INSERTING THEN RAISE_APPLICATION_ERROR (-20500,你只能在工作时间插入员工表 ELSIF UPDATING (SALARY) THEN RAISE_APPLICATION_ERROR (-20503,你只能在工作时间更新员工表 的数据.); ELSE  RAISE_APPLICATION_ERROR (-20504,你只能在工作事件操作员工表 END; /  END IF; END IF; 运行测试 分别运行以下测试语句,给出运行结果。并理解为什么会有这样的结果。 insert into employees values (1,a,2222,AD_PRES); insert into employees values (2,b,2222,AD_VP); 给出测试结果截图: delete from employees; 给出测试结果截图: update employees set salary=3000; 给出测试结果截图: 在 insert 或 update 中使用:new 阅读并理解以下程序,理解其功能,给出运行测试结果。 创建触发器 --在 insert 或 update 中使用:new-- CREATE OR REPLACE TRIGGER restrict_salary BEFORE INSERT OR UPDATE OF salary ON employees FOR EACH ROW BEGIN --

文档评论(0)

tianya189 + 关注
官方认证
内容提供者

该用户很懒,什么也没介绍

认证主体阳新县融易互联网技术工作室
IP属地上海
统一社会信用代码/组织机构代码
92420222MA4ELHM75D

1亿VIP精品文档

相关文档