sql >> Databasteknik >  >> RDS >> Oracle

Använd värdet för en strängvariabel i SQL FOR-IN (SELECT) loop

Om du antar Oracles PL/SQL kan du öppna en REFCURSOR använda dynamisk sträng och anropa den i en LOOP..

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;



  1. SQL Server ODBC-drivrutin ger inga fel

  2. Skapa ny tabell i befintlig DB i separat SQLiteOpenHelper-klass

  3. Generering av sekvenser i ordning

  4. R:[unixODBC][Driver Manager]Kan inte öppna lib 'SQL Server':filen hittades inte