1

次のコードのように、SQL を使用してオブジェクトをクエリしたいと考えています。

パッケージ:


PACKAGE DRAWING AS 
TYPE AWARD_NUMBER_ROW IS RECORD (
      A_NUMBER    VARCHAR2 (10),
      A_TYPE      char (1)
  ); 

TYPE AWARD_ROW IS RECORD (
      A_NUMBER    VARCHAR2 (10),
      A_NAME      VARCHAR2 (50)
  ); 

TYPE AWARD_NUMBER_TABLE IS TABLE OF AWARD_NUMBER_ROW  INDEX BY PLS_INTEGER; 
TYPE AWARD_TABLE IS TABLE OF AWARD_ROW  INDEX BY PLS_INTEGER; 

AWARD AWARD_TABLE;
AWARD_T AWARD_TABLE; 

PROCEDURE DRAWING (AWARD_NUMBER IN AWARD_NUMBER_TABLE);

END DRAWING;

体:


create or replace 
PACKAGE BODY DRAWING AS
PROCEDURE DRAWING (AWARD_NUMBER IN AWARD_NUMBER_TABLE) AS
BEGIN
    EXECUTE IMMEDIATE
    'SELECT * FROM AWARD_INF'
    BULK COLLECT INTO AWARD_T;

    /*
          error is from here. AWARD_T does not exist or is marked for delete
    */
    SELECT T.* bulk collect into AWARD FROM TABLE(AWARD_T ) T WHERE T.A_NAME = '123456789' ;

END DRAWING; 
END INVOICE_DRAWING

ここに例外メッセージがあります。

ORA-21700: オブジェクトが存在しないか、削除対象としてマークされています "オブジェクトが存在しないか、削除対象としてマークされています" *原因: ユーザーが、存在しないか削除対象としてマークされているオブジェクトに対して不適切な操作を実行しようとしました。ピン留め、削除、更新などの操作は、存在しないか、削除対象としてマークされているオブジェクトには適用できません。*処置: 参照を再初期化して既存のオブジェクトを参照するか、オブジェクトのマークを解除する必要があります。

どうすれば修正できますか??

4

0 に答える 0