sql >> Databasteknik >  >> RDS >> Oracle

Kapslade markörer i PL/SQL

Statiska markörer kan bara komma åt statiska objekt. Med andra ord fungerar statiska markörer endast om alla tabeller och kolumner är kända vid kompileringstillfället.

Om du behöver komma åt en tabell vars namn bara kommer att vara känt under körningen måste du använda dynamisk SQL . Du kan till exempel använda en REF CURSOR i ditt fall:

DECLARE
   var_table_name    VARCHAR2(30);
   var_dimension_key VARCHAR2(30);
   cur_dimension_key SYS_REFCURSOR;
BEGIN
   FOR cur_all_dim IN (SELECT table_name
                         FROM dba_tables
                        WHERE dba_tables.tablespace_name = 'USERS'
                          AND dba_tables.owner = 'DWH_CORE'
                          AND UPPER(dba_tables.table_name) LIKE ('%DIM%%')
                          AND UPPER(dba_tables.table_name) NOT LIKE ('%TEMP%')
                          AND UPPER(dba_tables.table_name) NOT LIKE ('%DEBUG%')
                          AND UPPER(dba_tables.table_name) NOT LIKE ('%LOG%')) 
   LOOP      
      OPEN cur_dimension_key 
       FOR 'SELECT dimention_key 
              FROM ' || cur_all_dim.table_name;
      LOOP
         FETCH cur_dimensions_key INTO var_dimension_key;
         EXIT WHEN cur_dimensions_key%NOTFOUND;
         dbms_output.put_line(cur_all_dim.table_name);
         dbms_output.put_line(var_dimension_key);      
      END LOOP;
      CLOSE cur_dimension_key;
   END LOOP;
END;


  1. Oracle SQL - Rund - Halv

  2. installera paket från docker-compose.yml i docker-behållaren

  3. Vill du inkludera rubriker när du använder SELECT INTO OUTFILE?

  4. MySQL konstigt beteende för jämförelseoperatör (!=/<>) dvs NotEqualTo