sql >> Databáze >  >> RDS >> Oracle

Opakované opakování stejné proměnné vazby při použití dynamické struktury SQL OPEN...FOR v Oracle PL/SQL

Parametr musíte zahrnout dvakrát do klauzule USING:

 OPEN emp_cv FOR sql_stmt USING my_job, my_job;

Zde je váš příklad, ale zjednodušený:

DECLARE
   TYPE EmpCurTyp IS REF CURSOR;
   emp_cv   EmpCurTyp;
   emp_rec  varchar2(10);
   sql_stmt VARCHAR2(200);
   my_job   VARCHAR2(15) := 'X';
BEGIN

   OPEN emp_cv FOR 'select * from dual where dummy = :j or dummy = :j' 
    USING my_job, my_job;
   LOOP
      FETCH emp_cv INTO emp_rec;
      EXIT WHEN emp_cv%NOTFOUND;
   END LOOP;
   CLOSE emp_cv;
END;


  1. chybný počet v dotazu

  2. Dotaz na to, jak přidat chybějící data v sql

  3. Jak exportovat pomocí DATA_PUMP do kbelíku S3?

  4. Jak získat poslední den měsíce v mysql zadáním měsíce a roku jako vstupu