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

Utiliser la valeur d'une variable de chaîne dans la boucle SQL FOR-IN (SELECT)

En supposant le PL/SQL d'Oracle, vous pouvez ouvrir un REFCURSOR en utilisant une chaîne dynamique et appelez-la dans une BOUCLE..

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;