web-dev-qa-db-ja.com

ループ暗黙カーソル用のPL / SQL

2つのテーブルEMPLOYEESDEPARTMENTSがあり、department_idDEPARTMENTSの主キー、EMPLOYEESの外部キーとして。

特定の部門に属するすべての従業員名を印刷したい。 JOINSまたはEXPLICITカーソルで簡単に実現できることは知っています。 FORループとIMPLICITカーソルを試してみませんか。

私の質問は、このようにINTOを書くことが構文的に正しいかどうかです。もしそうなら、なぜ値を割り当てないのですか?

DECLARE
    emp_dept_id employees.department_id%TYPE;
    emp_emp_id employees.employee_id%TYPE;
    emp_last_name employees.last_name%TYPE;
    dept_dept_id departments.department_id%TYPE;
    dept_dept_name departments.department_name%TYPE;
    v_count number DEFAULT 0;
BEGIN
    FOR i IN (SELECT DISTINCT department_id, department_name
                INTO dept_dept_id, dept_dept_name
        FROM departments)
    LOOP
        --v_COUNT := v_COUNT + 1;
        DBMS_OUTPUT.PUT_LINE('HELLO'||dept_dept_id||' '||dept_dept_name);
        FOR j IN (SELECT employee_id, last_name
            INTO emp_emp_id, emp_last_name
            FROM employees)
            --WHERE department_id=dept_dept_id)
        LOOP
            DBMS_OUTPUT.PUT_LINE(emp_emp_id||' '||emp_last_name);
            v_COUNT := v_COUNT + 1;
        END LOOP;
    END LOOP;
    DBMS_OUTPUT.PUT_LINE(v_COUNT);
END;
6
qasim.hasnain

暗黙のカーソルではINTOを使用しません。

    DECLARE
        emp_dept_id employees.department_id%TYPE;
        emp_emp_id employees.employee_id%TYPE;
        emp_last_name employees.last_name%TYPE;
        v_count number DEFAULT 0;
    BEGIN
        FOR i IN (SELECT DISTINCT department_id, department_name
            FROM departments)
        LOOP
            --v_COUNT := v_COUNT + 1;
            DBMS_OUTPUT.PUT_LINE('HELLO'||i.department_id||' '||i.department_name);
            FOR j IN (SELECT employee_id, last_name
                INTO emp_emp_id, emp_last_name
                FROM employees)
                --WHERE department_id=i.department_id)
            LOOP
                DBMS_OUTPUT.PUT_LINE(emp_emp_id||' '||emp_last_name);
                v_COUNT := v_COUNT + 1;
            END LOOP;
        END LOOP;
        DBMS_OUTPUT.PUT_LINE(v_COUNT);
    END;
    /
18
David Aldridge

このページを確認してください: http://www.techonthenet.com/Oracle/loops/cursor_for.php

あなたがしようとしていることが正当だとは思いません。これを2つのステップに分割します。FORループとINTOです。 FOR INにSELECTを含めることはできますが、INTOにすることはできません。

0
Robert Harvey