2012-02-16 9 views
2

参照を使用するpl/sqlブロックを作成しようとしています。基本的に、これは私が今までに得たものです。それらはどちらも個々のカーソルとして機能します。私は参照するのが少し難しいと思っています。私が必要とするのは部門名を列挙し、次にemp_cursorに行き、department_id = outer cursor department _idにあるすべての従業員をリストすることです。Oracle PL/SQL参照カーソルhow to

set serveroutput on 
declare 
    cursor dept_cursor is 
    select department_id, department_name 
    from departments 
    where department_id < 100; 
    dep_id departments.department_id%type; 
    dep_name departments.department_name%type; 

    cursor emp_cursor is 
     select last_name, job_id, hire_date, salary 
     from employees 
     where employee_id < 120 and department_id =/*Need reference from deptartmens.departments_id*/department_id; 
     emp_ln employees.last_name%type; 
     emp_jid employees.job_id%type; 
     emp_hd employees.hire_date%type; 
     emp_sal employees.salary%type; 

begin 
    for rec_dept in dept_cursor loop 
     dbms_output.put_line('Department Number: '||rec_dept.department_id|| ' Department Name: ' || rec_dept.department_name); 
     dbms_output.put_line('---------------------------------------------'); 
     for rec_emp in emp_cursor loop 
     dbms_output.put_line(rec_emp.last_name||' ' || rec_emp.job_id ||' ' || rec_emp.hire_date ||' '|| rec_emp.salary); 
     end loop; 
     dbms_output.put_line('---------------------------------------------'); 
    end loop; 

end ; 

たとえば、出力は次のようになります。あなたが必要なもの

Department Number : 10 Department Name : Administration 
---------------------------------------------------------------------------------------- 
Department Number : 20 Department Name : Marketing 
---------------------------------------------------------------------------------------- 
Department Number : 30 Department Name : Purchasing 
Raphaely PU_MAN 07-DEC-94 11000 
Khoo PU_CLERK 18-MAY-95 3100 
Baida PU_CLERK 24-DEC-97 2900 
Tobias PU_CLERK 24-JUL-97 2800 
Himuro PU_CLERK 15-NOV-98 2600 
Colmenares PU_CLERK 10-AUG-99 2500 
---------------------------------------------------------------------------------------- 

答えて

1

あなたはパラメータ化カーソルとしてEMP_CURSOR宣言することができます。パフォーマンスの観点から、

Department Number: 10 Department Name: Administration 
--------------------------------------------- 
--------------------------------------------- 
Department Number: 20 Department Name: Marketing 
--------------------------------------------- 
--------------------------------------------- 
Department Number: 30 Department Name: Purchasing 
--------------------------------------------- 
Raphaely PU_MAN 07-DEC-02 11000 
Khoo PU_CLERK 18-MAY-03 3100 
Baida PU_CLERK 24-DEC-05 2900 
Tobias PU_CLERK 24-JUL-05 2800 
Himuro PU_CLERK 15-NOV-06 2600 
Colmenares PU_CLERK 10-AUG-07 2500 
--------------------------------------------- 
Department Number: 40 Department Name: Human Resources 
--------------------------------------------- 
--------------------------------------------- 
Department Number: 50 Department Name: Shipping 
--------------------------------------------- 
--------------------------------------------- 
Department Number: 60 Department Name: IT 
--------------------------------------------- 
Hunold IT_PROG 03-JAN-06 9000 
Ernst IT_PROG 21-MAY-07 6000 
Austin IT_PROG 25-JUN-05 4800 
Pataballa IT_PROG 05-FEB-06 4800 
Lorentz IT_PROG 07-FEB-07 4200 
--------------------------------------------- 
Department Number: 70 Department Name: Public Relations 
--------------------------------------------- 
--------------------------------------------- 
Department Number: 80 Department Name: Sales 
--------------------------------------------- 
--------------------------------------------- 
Department Number: 90 Department Name: Executive 
--------------------------------------------- 
King AD_PRES 17-JUN-03 24000 
Kochhar AD_VP 21-SEP-05 17000 
De Haan AD_VP 13-JAN-01 17000 
--------------------------------------------- 

HRスキーマに次のような出力を生成します

declare 
    cursor dept_cursor is 
    select department_id, department_name 
    from departments 
    where department_id < 100; 
    dep_id departments.department_id%type; 
    dep_name departments.department_name%type; 
    cursor emp_cursor(p_department_id IN NUMBER) is 
    select last_name, job_id, hire_date, salary 
    from employees 
    where employee_id < 120 
     and department_id = p_department_id; 
    emp_ln employees.last_name%type; 
    emp_jid employees.job_id%type; 
    emp_hd employees.hire_date%type; 
    emp_sal employees.salary%type; 
begin 
    for rec_dept in dept_cursor loop 
    dbms_output.put_line('Department Number: '||rec_dept.department_id|| ' Department Name: ' || rec_dept.department_name); 
    dbms_output.put_line('---------------------------------------------'); 
    for rec_emp in emp_cursor(rec_dept.department_id) loop 
     dbms_output.put_line(rec_emp.last_name||' ' || rec_emp.job_id ||' ' || rec_emp.hire_date ||' '|| rec_emp.salary); 
    end loop; 
    dbms_output.put_line('---------------------------------------------'); 
    end loop; 
end ; 

のようなものは、次の2つのテーブルを結合するのではなく、独自のネストされたループを書くのに役立っずっと良いだろうPL/SQLで使用します。

2

はカーソル変数です:次に

cursor emp_cursor (v_dept_id number) is 
    select last_name, job_id, hire_date, salary 
    from employees 
    where employee_id < 120 and department_id = v_dept_id; 

for rec_emp in emp_cursor loop 

は次のようになります。

for rec_emp in emp_cursor(rec_dept.department_id) loop