sql >> Database teknologi >  >> RDS >> Oracle

Hvordan specificerer du IN-sætning i en dynamisk forespørgsel ved hjælp af en variabel?

Ligesom i @Sathya-linket kan du binde varrayen (jeg tog @Codo-eksempel):

CREATE OR REPLACE TYPE str_tab_type IS VARRAY(10) OF VARCHAR2(200);
/
DECLARE
  l_str_tab str_tab_type;
  l_count NUMBER;
  v_sql varchar2(3000);
BEGIN
  l_str_tab := str_tab_type();
  l_str_tab.extend(2);
  l_str_tab(1) := 'TABLE';
  l_str_tab(2) := 'INDEX';

  v_sql := 'SELECT COUNT(*) FROM all_objects WHERE object_type IN (SELECT COLUMN_VALUE FROM TABLE(:v_list))';

  execute immediate v_sql into l_count using l_str_tab;

  dbms_output.put_line(l_count);
END;
/

OPDATERING: den første kommando kan erstattes med:

CREATE OR REPLACE TYPE str_tab_type IS TABLE OF VARCHAR2(200);
    /

så ring til:

l_str_tab.extend(1);

hver gang du tilføjer en værdi



  1. Sådan opretter du forbindelse til en database ved hjælp af Sequel Pro

  2. Hvordan kontrollerer man, om filen findes i PL/SQL?

  3. Oracle - Klon tabel - Struktur, data begrænsninger og det hele

  4. Hvordan trunkerer man en tabel med begrænsning af fremmednøgler?