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

PL/SQL weist Abfrageergebnisse einem CLOB zu

Beachten Sie diesen Teil in Ihrem Code:

WHILE cursor1%NOTFOUND

Ihre Schleife wird niemals für einen nicht leeren Datensatz ausgeführt. Verwenden Sie stattdessen Folgendes:

WHILE cursor1%FOUND

Oder verwenden Sie noch besser den impliziten Cursor:

FOR cursor1 in
        (SELECT rec,
               d_id,
               customer,
               wife,
               date_rec,
               special_h,
               g_amount,
               credit_amount,
               a_number,
               a__name
          FROM  (your query here))
LOOP
v_clob :=
               v_clob
            || cursor1.rec
            || ','
            || cursor1.d_id
            || ','
            || cursor1.customer
            || ','
            || cursor1.wife
            || ','
            || cursor1.date_rec
            || ','
            || cursor1.special_h
            || ','
            || cursor1.g_amount
            || ','
            || cursor1.credit_amount
            || ','
            || cursor1.a_number
            || ','
            || cursor1.a__name
            || UTL_TCP.crlf;
END LOOP;