Oracle
 sql >> Datenbank >  >> RDS >> Oracle

So deklarieren Sie einen Cursor nach dem Anfangsabschnitt einer Oracle PL/SQL-Prozedur

Dazu müssten Sie einen neuen Block deklarieren:

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;

Ich verstehe jedoch nicht ganz, warum Sie diesen Cursor nicht einfach zusammen mit Cursor y deklarieren können, der mit einem Parameter definiert ist:

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)
            ); 

Sie könnten den Cursor dann folgendermaßen referenzieren:

FOR met IN x(t.FCODE) LOOP