Oracle
 sql >> Base de données >  >> RDS >> Oracle

Comment déclarer un curseur après la section de début d'une procédure Oracle PL/SQL

Pour ce faire, vous devez déclarer un nouveau bloc :

for t in y loop 
    DECLARE
    cursor X IS ( 
                SELECT DISTINCT s.NIF PREMISE,a.COD_UNICOM READING, A.COD_LECT_AREA AREA
                FROM SUMCON s, LECT_AREAS a 
                WHERE a.COD_UNICOM  = t.FCODE
                AND s.NUM_SUM IN (select num_sum from RFC_UPD_NEW_MRSP_POOL where cod_unicom = t.FCODE)
                ); 
     BEGIN

        for met in x loop 
...
        end loop;
     END;

Cependant, je ne vois pas très bien pourquoi vous ne pouvez pas simplement déclarer ce curseur avec le curseur y, défini avec un paramètre :

cursor X (p_FCODE RFC_UPD_NEW_MRSP_POOL.cod_unicom%TYPE) IS ( 
            SELECT DISTINCT s.NIF PREMISE,a.COD_UNICOM READING, A.COD_LECT_AREA AREA
            FROM SUMCON s, LECT_AREAS a 
            WHERE a.COD_UNICOM  = p_FCODE
            AND s.NUM_SUM IN (select num_sum from RFC_UPD_NEW_MRSP_POOL where cod_unicom = p_FCODE)
            ); 

Vous pouvez alors référencer le curseur ainsi :

FOR met IN x(t.FCODE) LOOP