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

PL/SQL affectant les résultats de la requête à un CLOB

Notez cette partie dans votre code :

WHILE cursor1%NOTFOUND

Votre boucle ne sera jamais exécutée pour un ensemble de données non vide. Utilisez ceci à la place :

WHILE cursor1%FOUND

Ou encore mieux utiliser le curseur implicite :

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;