создать и использовать таблицу в одном блоке pl sql - PullRequest
0 голосов
/ 26 февраля 2020

Я пытаюсь создать пользовательское оповещение для облачного элемента управления oracle для долгосрочных операторов. Вот почему я не могу выполнить некоторые определенные c действия (например, создать требуемую таблицу) перед выполнением синхронизации. Существует проблема:

Error report -
ORA-06550: line 32, column 10:
PL/SQL: ORA-00942: table or view does not exist
ORA-06550: line 30, column 5:
PL/SQL: SQL Statement ignored
06550. 00000 -  "line %s, column %s:\n%s"
*Cause:    Usually a PL/SQL compilation error.
*Action:

Когда я запускаю этот код:

SET SERVEROUTPUT ON
DECLARE
    -- VARIABLES
    sql_id_var V$SESSION.sql_id%TYPE;
    SQL_CHILD_NUMBER_var  V$SESSION.SQL_CHILD_NUMBER%TYPE;
    ALREADY_EXISTS NUMBER := 0;

    --TO GET SQL_ID,CHILD_ID
    CURSOR  sql_id_cursor IS
    select ses.sql_id, ses.SQL_CHILD_NUMBER
    from V$SESSION ses
    where SES.STATUS = 'ACTIVE'
    and SES.USERNAME is not null
    --and Ses.AUDSID <> userenv('SESSIONID') 
    and ses.sql_id is not null
    and (SYSDATE - ses.SQL_EXEC_START) > 5/(24*60*60) --SECONDS;

begin

 --CREATE TABLE TO STORE SQL_ID OF LONG RUNNING QUERIES
 EXECUTE IMMEDIATE 'CREATE TABLE LONG_SQL (SQL_ID VARCHAR2(13),
                     SQL_CHILD_NUMBER NUMBER,
                     DETECTED_DATE DATE)' ;
  exception when others then
  if SQLCODE = -00955 then null;dbms_output.put_line( 'TABLE EXISTS ' ); else raise; end if;


  --PROCESSING EVERY LONG QUER
  FOR sql_id_row IN sql_id_cursor
  LOOP
    dbms_output.put_line( 'SQL_ID: ' || sql_id_row.sql_id || ' , SQL_CHILD_NUMBER: ' ||  sql_id_row.SQL_CHILD_NUMBER || ' , NOW IS :' || SYSDATE);
    SELECT COUNT(*)
    INTO ALREADY_EXISTS
    FROM LONG_SQL
    WHERE LONG_SQL.SQL_ID = sql_id_row.sql_id
    AND LONG_SQL.SQL_CHILD_NUMBER = sql_id_row.SQL_CHILD_NUMBER;
    dbms_output.put_line( 'SQL_ID: ' || sql_id_row.sql_id || ' , SQL_CHILD_NUMBER: ' ||  sql_id_row.SQL_CHILD_NUMBER || ' , FOUND ' || ALREADY_EXISTS || ' TIMES INTO LOG TABLE');

  END LOOP;


end;
/

Внутри этого pl sql я создаю таблицу LONG_ SQL если он не существует, а затем я хочу сделать запрос, который использует эту новую таблицу. Не могли бы вы предложить что-то здесь, чтобы обойти это? Можно ли создать, а затем использовать таблицу в одном блоке pl sql?

1 Ответ

2 голосов
/ 26 февраля 2020

Те, кто живут по Dynami c SQL, d ie по Dynami c SQL.

Если вы создали таблицу динамически, вам придется использовать ее также динамически , Другими словами, этот запрос:

SELECT COUNT(*)
    INTO ALREADY_EXISTS
    FROM LONG_SQL ...

также должен быть dynamici c и выполняться с execute immediate.

...