预览加载中,请您耐心等待几秒...
1/10
2/10
3/10
4/10
5/10
6/10
7/10
8/10
9/10
10/10

亲,该文档总共28页,到这已经超出免费预览范围,如果喜欢就直接下载吧~

如果您无法下载资料,请参考说明:

1、部分资料下载需要金币,请确保您的账户上有足够的金币

2、已购买过的文档,再次下载不重复扣费

3、资料包下载后请先用软件解压,在使用对应软件打开

《数据库系统》实验报告七 学号姓名实验时间2014-12-31实验名称触发器实验学时2准备材料1.SQLPlus命令手册 2.PL/SQL用户手册 3.实验教材中实验七扩展实验1.完成触发器的定义、执行与管理操作 (此部分内容不要求在实验室完成,不用写入实验报告。)实验环境Oracle9i(及以上版本)服务器 SQLPlus/SQLPlusworksheet客户端实验目的1熟悉PL/SQL语法 2.利用PL/SQL编程访问数据库实验内容及步骤完成实验指导书实验七所有实验内容 【训练1】 CREATETABLElogs( LOG_IDNUMBER(10)PRIMARYKEY, LOG_TABLEVARCHAR2(10)NOTNULL, LOG_DMLVARCHAR2(10), LOG_KEY_IDNUMBER(10), LOG_DATEDATE, LOG_USERVARCHAR2(15) ); CREATESEQUENCElogs_id_squINCREMENTBY1 STARTWITH1MAXVALUE9999999NOCYCLENOCACHE; CREATEORREPLACETRIGGERDML_LOG BEFORE--触发时间为操作前 DELETEORINSERTORUPDATE--由三种事件触发 ONemp FOREACHROW--行级触发器 BEGIN IFINSERTINGTHEN INSERTINTOlogs VALUES(logs_id_squ.NEXTVAL,'EMP','INSERT',:new.empno,SYSDATE,USER); ELSIFDELETINGTHEN INSERTINTOlogs VALUES(logs_id_squ.NEXTVAL,'EMP','DELETE',:old.empno,SYSDATE,USER); ELSE INSERTINTOlogs VALUES(logs_id_squ.NEXTVAL,'EMP','UPDATE',:new.empno,SYSDATE,USER); ENDIF; END; INSERTINTOemp(empno,ename,job,sal)VALUES(8001,'MARY','CLERK',1000); COMMIT; SELECT*FROMLOGS; 【练习1】修改、删除刚刚插入的雇员记录,提交后检查LOGS表的结果。 updateemp setsal=sal*5 whereename='MARY'; COMMIT; DELETEFROMempWHEREempno=8001; COMMIT; SELECT*FROMLOGS; 【练习2】为DEPT表创建同样的触发器,使用LOGS表进行记录,并检验结果。 CREATEORREPLACETRIGGERDEPT_LOG BEFORE--触发时间为操作前 DELETEORINSERTORUPDATE--由三种事件触发 ONdept FOREACHROW--行级触发器 BEGIN IFINSERTINGTHEN INSERTINTOlogs VALUES(logs_id_squ.NEXTVAL,'DEPT','INSERT',:new.deptno,SYSDATE,USER); ELSIFDELETINGTHEN INSERTINTOlogs VALUES(logs_id_squ.NEXTVAL,'DEPT','DELETE',:old.deptno,SYSDATE,USER); ELSE INSERTINTOlogs VALUES(logs_id_squ.NEXTVAL,'DEPT','UPDATE',:new.deptno,SYSDATE,USER); ENDIF; END; INSERTINTOdept(deptno,dname,loc)VALUES(50,'JIAN','GUANGZHOU'); COMMIT; SELECT*FROMLOGS; 【训练2】 CREATETABLElogerr( NUMNUMBER(10)NOTNULL, MESSAGEVARCHAR2(50)NOTNULL ); CREATEORREPLACETRIGGERlog_sal BEFORE UPDATEOFsal ONemp FOREACHROW WHEN(new.job='CLERK'AND(ABS(new.sal-old.sal)>200)) DECLARE v_noNUMBER; BEGIN SELECTCOUNT(*)INTOv_noFROMlogerr;