WEB开发网
开发学院数据库Oracle Oracle PL/SQL入门之案例实践 阅读

Oracle PL/SQL入门之案例实践

 2006-12-30 12:00:38 来源:WEB开发网   
核心提示: 给指定部门的员工加薪,这实际上是一个复合查询,Oracle PL/SQL入门之案例实践(2),首先需要把所有该部门的员工塞选出来,然后对这些员工的薪水进行相应的改动,把每次更改进行记录,这样就达到了要求3的目的了,依照这一思路,代码如下:(需要注意的是:将要加薪的部门作为参数

给指定部门的员工加薪,这实际上是一个复合查询,首先需要把所有该部门的员工塞选出来,然后对这些员工的薪水进行相应的改动。依照这一思路,代码如下:

(需要注意的是:将要加薪的部门作为参数,这样的存储过程更有灵活性。)

create or replace procedure add_salary(p_dept_name varchar2) as
v_dept_name varchar2(20):=p_dept_name;
begin
 update emp set emp.EMP_SALARY=emp.EMP_SALARY*1.2 where emp.EMP_ID in (select emp.EMP_ID from emp,dept where emp.EMP_ID=dept.EMP_ID and dept.DEPT_ID='??ê?2?');
end add_salary;

要求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=:new.salary=:old.salary;
dbms_output.PUT_LINE('old salary is: '|| :old.salary);
dbms_output.PUT_LINE('old salary is: '|| :new.salary);
dbms_output.PUT_LINE('old salary is: '|| to_char(salary_balance));
end print_salary_change;

要求4:

Tags:Oracle PL SQL

编辑录入:爽爽 [复制链接] [打 印]
赞助商链接