1 / 11
文档名称:

实验7-触发器(共11页).doc

格式:doc   大小:203KB   页数:11页
下载后只包含 1 个 DOC 格式的文档,没有任何的图纸或源代码,查看文件列表

如果您已付费下载过本站文档,您可以点这里二次下载

分享

预览

实验7-触发器(共11页).doc

上传人:wwlgqnh 2022/4/13 文件大小:203 KB

下载得到文件列表

实验7-触发器(共11页).doc

相关文档

文档介绍

文档介绍:精选优质文档-----倾情为你奉上
精选优质文档-----倾情为你奉上
专心---专注---专业
专心---专注---专业
精选优质文档-----倾情为你奉上
专心---专注---专业
成绩
大型数据库技术实验报告
实验s_table_dept(111,'gh',10001);
精选优质文档-----倾情为你奉上
精选优质文档-----倾情为你奉上
专心---专注---专业
专心---专注---专业
精选优质文档-----倾情为你奉上
专心---专注---专业
ins_table_dept(111,'qwe',10002);
ins_table_dept(112,'rffff',10003);
ins_table_dept(113,'oooooo',10004);
end;
2. 要求2:
  给指定部门的员工加薪,这实际上是一个复合查询,首先需要把所有该部门的员工选出来,然后对这些员工的薪水进行相应的改动。代码如下:
  (需要注意的是:将要加薪的部门作为参数,这样的存储过程更有灵活性。)
create or replace procedure add_salary(p_dept_id number ) as
  begin
   update emp
set =*
where in (
select
from emp,dept
where = and =p_dept_id);
  end add_salary;
精选优质文档-----倾情为你奉上
精选优质文档-----倾情为你奉上
专心---专注---专业
专心---专注---专业
精选优质文档-----倾情为你奉上
专心---专注---专业
原表数据:
创建的过程(我改过)
修改后(选定部门111):
精选优质文档-----倾情为你奉上
精选优质文档-----倾情为你奉上
专心---专注---专业
专心---专注---专业
精选优质文档-----倾情为你奉上
专心---专注---专业
3. 要求3:
  建立日志对薪水的变动情况形成一个追踪,也就是说,如果对某个职员的薪水进行变更就应该将其相应的变更记录全部记下来。如果对emp表的salary字段创建一个触发器,来监视对salary的更改,把每次更改进行记录,这样就达到了要求3的目的了。
  create or replace trigger print_salary_change
before delete or insert or update on emp
--触发事件
for each row
-- 每修改一行都需要调用此过程
declare
--只有触发器的声明需要declare,过程和函数都不需要
  salary_balance number;
  begin
  --:new 与:old分别代表该行在修改前和修改后的记录
salary_balance=:;
=:;
  ('old salary is: '|| :);
  ('old salary is: '|| :);
  ('old salary is: '|| to_char(salary_balance));
精选优质文档-----倾情为你奉上
精选优质文档-----倾情为你奉上
专心---专注---专业
专心---专注---专业
精选优质文档-----倾情为你奉上
专心---专注---专业
  end print_salary_change;
4. 要求4:与其他语言(c/c++等)相比,PL/SQL的测试有其不同之处,归纳下来有三种方法:
  (1) 使用DBMS_OUTPUT包的PUT_LINE方法来显示中间变量,以此来观察程序是否存在逻辑错误。
  (2) 插入测试表的方法。即创建一个临时的中间表,然后把所有涉及到的中间变量的结果都作为记录插入到中间表中,这样可以查询表中的结果来观察程序的执行情况。
  (3) 使用异常处理手段,对可疑的程序段使用begin … end ,然后可以在exception里进行异常捕获处理。
  这里使用第二种方