- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
大型数据库技术(Oracle)06
实验6 触发器与作业
姓名: 刘鸿辉 学号: 1107022125 专业: 网络工程 班级: 11网络工程 同组人: 无 实验日期: 2013/11/28
【实验目的与要求】
理解什么是触发器
掌握触发器的设计与使用
掌握在Oracle中完成定时作务的方法
【实验内容与步骤】
相关说明:本实验中前面实验创建的触发器可能对后面的实验产生干扰,若出现这种情况,请把前面触发器删除,再完成后面实验。建议每完成一个实验题后,即将该题相关的触发器删除,以免对后面实验产生干扰。
触发器创建与删除语法
1.触发器的创建
触发器是一种在发生数据库事件时自动运行的PL/SQL
语法如下:
CREATE [OR REPLACE] TIGGER触发器名 触发时间 触发事件
ON表名
[FOR EACH ROW]
BEGIN
pl/sql语句
END
2.触发器的删除
DROP TRIGGER trigger_name
触发器基础
以下程序展示的是触发器的基本使用方法,请阅读并理解以下程序代码,给出运行结果。
1.创建测试表
--drop table employees;
create table employees(
id number(5),
name varchar2(30),
salary number(8,2),
job_id varchar2(20)
);
2.创建触发器
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;
/
insert into employees values (1,a,2222,aaaaa);
给出测试结果截图:
(2)将系统时间修改为周六,再Insert一条记录,给出并比较两次运行的结果。
给出测试结果截图:
使用触发器监控数据更新操作
阅读以下程序,理解程序功能,给出运行测试结果。
1.创建触发器
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 IF;
END IF;
END;
/
2.运行测试
分别运行以下测试语句,给出运行结果。并理解为什么会有这样的结果。
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
阅读并理解以下程序,理解其功能,给出运行测试结果。
1.创建触发器
--在insert或update中使用:new--
CREATE OR REPLACE TRIGGER restric
您可能关注的文档
最近下载
- TCPRA 4000.9-2025 文化数据服务平台技术要求 第9部分:运维管理系统.docx VIP
- 2025年部编六上语文《草原》公开课教案教学设计【一等奖】.pdf VIP
- 《直播电商基础与实务》-教案 项目8直播电商平台运营实战-教案.doc
- 抗凝药物临床应用指南.pptx VIP
- 学堂在线《医学科研设计》作业单元考核答案.docx VIP
- 庞加莱猜想证明概述.pdf VIP
- 2024年秋季新人教版9年级上册化学全册课件.pptx
- 药物化学 磺胺类药物及抗菌增效剂 磺胺类药物及抗菌增效剂 电子教案.doc VIP
- 高中地理校本课程教案.docx VIP
- 2024年山东成人学士学位英语考试真题解析 .docx VIP
文档评论(0)