sql >> データベース >  >> RDS >> Oracle

Oracle:最近のSQL構文エラーを取得する方法はありますか?

    Oracleで、すべてのエラーをログに記録するトリガーを作成できます(または、ほとんどすべて-NO_DATA_FOUNDはエラーとは見なされません)。以下の例では、スキーマのエラーはすべてTRACK_DETAILテーブルに記録されます(1つの行でエラーが発生し、次の行でSQLが失敗しました)。シーケンス番号、日付/時刻などを使用して、より洗練されたものにすることができます。

    create table track_detail (val varchar2(4000));
    
    create or replace procedure track (p_text IN VARCHAR2) IS
      PRAGMA AUTONOMOUS_TRANSACTION;
    begin
      insert into track_detail(val)
      values (p_text);
      commit;
    end;
    .
    /
    create or replace TRIGGER log_err after servererror on schema
    DECLARE
      v_temp VARCHAR2(2000) := substr(dbms_utility.format_error_stack,1,2000);
      v_num NUMBER;
      v_sql_text ora_name_list_t;
    begin
      v_temp := translate(v_temp,'''','"');
      track(v_temp);
      v_num  := ora_sql_txt(v_sql_text);
      v_temp := null;
      BEGIN
        FOR i IN 1..v_num LOOP
          v_temp := v_temp || v_sql_text(i);
        END LOOP;
      EXCEPTION
        WHEN VALUE_ERROR THEN NULL;
      END;
      v_temp := translate(v_temp,''''||chr(0)||chr(10),'"');
      track(v_temp);
    end;
    /
    

    トリガーを終了したら、トリガーをドロップ(または無効化)することを忘れないでください。



    1. MySQLでの削除後の自動インクリメント

    2. fe_sendauth:パスワードが提供されていません

    3. MYSQLテーブルに新しい列を追加するにはどうすればよいですか?

    4. データを別のテーブルにコピーする