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

Verwenden Sie den Wert einer Zeichenfolgenvariablen in der SQL FOR-IN (SELECT)-Schleife

Unter der Annahme von Oracles PL/SQL können Sie einen REFCURSOR öffnen Verwenden Sie einen dynamischen String und rufen Sie ihn in einer LOOP auf..

PROCEDURE run(p_boolean BOOLEAN)
IS
BEGIN
  DECLARE
    v_mystring VARCHAR(50);
    v_my_ref_cursor sys_refcursor;
  BEGIN
    IF p_boolean = TRUE
    THEN
      v_mystring := 'SELECT something...';
    ELSE
      v_mystring := 'SELECT something else...';
    END IF;

    OPEN v_my_ref_cursor FOR v_mystring;

    LOOP
      FETCH v_my_ref_cursor INTO your_variables/record
      EXIT WHEN v_my_ref_cursor%NOTFOUND;
        ..

    END LOOP;
    CLOSE v_my_ref_cursor;

  END;
END;