程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 數據庫知識 >> SqlServer數據庫 >> 關於SqlServer >> Oracle PL/SQL入門案例實踐

Oracle PL/SQL入門案例實踐

編輯:關於SqlServer
 前面已經了解了關於PL/SQL編程的基礎,本文將結合一個案例來加深對這些知識點的理解。

  一. 案例介紹

  某數據庫有兩張表,是關於某公司員工資料、薪水和部門信息的,它們分別是emp表和dept表,兩張表的結構如下:

  要求如下:

  1、按照上表結構建立相應的表,並每張表寫入5組合法數據。

  2、操縱相關表,使得“技術部”的員工的薪水上漲20%。

  3、建立日志,追蹤薪水變動情況。

  4、建立測試包。

  二. 案例的分析與實現

  從前面案例的介紹不難看出,要求1考察點為基本SQL語句;要求2主要考察復合查詢;要求3是考察觸發器的應用;要求4的考察面相對多一些,不僅考察了包的創建,而且也考察了在PL/SQL中的測試方法。了解了這些考察的知識點,就可以一一去解決。

  要求1:

  首先根據前面表的結構可以創建兩張表:

  ——創建員工表

create table emp (emp_id number(5), emp_name varchar2(20), emp_salary number(4));

  ——部門表

create table dept (dept_id number(3), dept_name varchar2(20), emp_id number(5));

  建立了表之後就可以往表裡面寫數據了,這裡把添加表記錄的代碼寫入到相應的存儲過程。

/*給emp表添加記錄的存儲過程*/
create or replace procedure ins_table_emp(p_emp_id number,p_emp_name varchar2,p_emp_salary number) as
v_emp_id number:=p_emp_id;
v_emp_name varchar2(20):=p_emp_name;
v_emp_salary number:=p_emp_salary;
begin
 insert into emp values (v_emp_id,v_emp_name,v_emp_salary);
end ins_table_emp;

/*給dept表添加記錄的存儲過程*/
create or replace procedure ins_table_dept(p_dept_id number,p_dept_name varchar2,p_emp_id number) as
 v_dept_id number:=p_dept_id;
 v_dept_name varchar2(20):=p_dept_name;
 v_emp_id number:=p_emp_id;
begin
 insert into dept values (v_dept_id,v_dept_name,v_emp_id);
end ins_table_emp;

/*調用相應的存儲過程實現記錄添加*/
begin
 ins_table_emp(10000,'',4000);
 ins_table_emp(10001,'??èy',2300);
 ins_table_emp(10002,'3?t',3500);
 ins_table_emp(10003,'à???',3500);
 ins_table_emp(10004,'á?ò?',3500);

 ins_table_dept(111,'DD?t2?',10000);
 ins_table_dept(111,'DD?t2?',10001);
 ins_table_dept(111,'DD?t2?',10002);
 ins_table_dept(112,'??ê?2?',10003);
 ins_table_dept(113,'êD3?2?',10004);
end;

  要求2:

  給指定部門的員工加薪,這實際上是一個復合查詢,首先需要把所有該部門的員工塞選出來,然後對這些員工的薪水進行相應的改動。依照這一思路,代碼如下:

  (需要注意的是:將要加薪的部門作為參數,這樣的存儲過程更有靈活性。)

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;

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved