sql >> Database >  >> RDS >> Oracle

Gebruik de waarde van een stringvariabele in de SQL FOR-IN (SELECT)-lus

Ervan uitgaande dat Oracle's PL/SQL, kunt u een REFCURSOR openen dynamische String gebruiken en het in een LUS aanroepen..

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. haal de records van de laatste drie maanden uit de tabel

  2. session_start genereert fatale fout

  3. Hoe leeftijd (in jaren) te berekenen op basis van geboortedatum en getDate()

  4. Hoe MySQL datetime-waarde te converteren naar google chart api datetime