- 1、本文档共10页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 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
--
您可能关注的文档
- MyEclipse简单操作分析和总结.docx
- Myelicps快捷键分析和总结.docx
- Nastran 基础培训 3_有限元模型.docx
- Nastran 基础培训 4_控制卡片.docx
- Nastran 基础培训5_坐标系.docx
- Nastran 基础培训6_基本单元库.docx
- Nastran 基础培训7_材料性质.docx
- NCAP比较分析和总结.docx
- NCE答案分析和总结.docx
- NCRE二级MS-OFFICE高级应用无纸化考题.docx
- 10《那一年,面包飘香》教案.docx
- 13 花钟 教学设计-2023-2024学年三年级下册语文统编版.docx
- 2024-2025学年中职学校心理健康教育与霸凌预防的设计.docx
- 2024-2025学年中职生反思与行动的反霸凌教学设计.docx
- 2023-2024学年人教版小学数学一年级上册5.docx
- 4.1.1 线段、射线、直线 教学设计 2024-2025学年北师大版七年级数学上册.docx
- 川教版(2024)三年级上册 2.2在线导航选路线 教案.docx
- Unit 8 Dolls (教学设计)-2024-2025学年译林版(三起)英语四年级上册.docx
- 高一上学期体育与健康人教版 “贪吃蛇”耐久跑 教案.docx
- 第1课时 亿以内数的认识(教学设计)-2024-2025学年四年级上册数学人教版.docx
最近下载
- 6.2交友的智慧 课件-2024-2025学年道德与法治七年级上册(统编版2024).pptx VIP
- (完整版)高中生物知识点总结(完整版).pdf
- 浙江省上虞实验中学2020-2021学年八年级上学期第一次月考数学试题(含解析).doc
- 环保涂料建设项目环境影响报告书.pdf
- 重难点专题02 函数值域与最值十四大题型汇总(解析版).docx VIP
- 6.1友谊的真谛 课件 2024-2025学年七年级道德与法治上册 统编版2024.pptx VIP
- 《公司治理学》(李维安第四版)教学全套课件.pptx
- 迷雾水珠 高清钢琴谱五线谱.pdf
- 湖南省长沙市长郡2024-2025学年高三上学期月考试卷(一)+英语试卷(含解析,含听力原文无音频).pdf VIP
- 6.1 友谊的真谛 【课件】2024-2025学年七年级上册道德与法治 统编版2024).pptx VIP
文档评论(0)