1

手続きがあります

create or replace procedure dump_table_to_csv( p_tname in varchar2,
  2                                                 p_dir   in varchar2,
  3                                                 p_filename in varchar2 )
  4  is
  5      l_output        utl_file.file_type;
  6      l_theCursor     integer default dbms_sql.open_cursor;
  7      l_columnValue   varchar2(4000);
  8      l_status        integer;
  9      l_query         varchar2(1000)
 10                      default 'select * from ' || p_tname;
 11      l_colCnt        number := 0;
 12      l_separator     varchar2(1);
 13      l_descTbl       dbms_sql.desc_tab;
 14  begin
 15      l_output := utl_file.fopen( p_dir, p_filename, 'w' );
 16      execute immediate 'alter session set nls_date_format=''dd-mon-yyyy hh24:mi:ss'' 
';
 17  
 18      dbms_sql.parse(  l_theCursor,  l_query, dbms_sql.native );
 19      dbms_sql.describe_columns( l_theCursor, l_colCnt, l_descTbl );
 20  
 21      for i in 1 .. l_colCnt loop
 22          utl_file.put( l_output, l_separator || '"' || l_descTbl(i).col_name || '"' 
);
 23          dbms_sql.define_column( l_theCursor, i, l_columnValue, 4000 );
 24          l_separator := ',';
 25      end loop;
 26      utl_file.new_line( l_output );
 27  
 28      l_status := dbms_sql.execute(l_theCursor);
 29  
 30      while ( dbms_sql.fetch_rows(l_theCursor) > 0 ) loop
 31          l_separator := '';
 32          for i in 1 .. l_colCnt loop
 33              dbms_sql.column_value( l_theCursor, i, l_columnValue );
 34              utl_file.put( l_output, l_separator || l_columnValue );
 35              l_separator := ',';
 36          end loop;
 37          utl_file.new_line( l_output );
 38      end loop;
 39      dbms_sql.close_cursor(l_theCursor);
 40      utl_file.fclose( l_output );
 41  
 42      execute immediate 'alter session set nls_date_format=''dd-MON-yy'' ';
 43  exception
 44      when others then
 45          execute immediate 'alter session set nls_date_format=''dd-MON-yy'' ';
 46          raise;
 47  end;
 48  /

実行しようとすると

exec dump_table_to_csv('emp', 'C:\Temp','a.txt')

エラー (エラー) が発生します: ステートメントの実行中にエラーが発生しました: ORA-29280: 無効なディレクトリ パス ORA-06512: "LCM_EVAL.DUMP_TABLE_TO_CSV" の行 59 ORA-06512: 行 2 で

考えられる問題は何ですか?

4

3 に答える 3

1

エラー メッセージは明確です。パスが無効です。ほとんどの場合、それは単なるタイプミスです:C:/Temp存在しませんが、存在する可能性C:\Tempがあります。

助成金の問題もあるでしょう。PL/SQL では、特定の権限が与えられている場合にのみ、ディスクにアクセスできます。UTL_FILEドキュメントには、PL/SQLへのアクセスを許可する方法が説明されています:

  • (推奨) dba アカウントでディレクトリを作成し、ユーザーにアクセス権を付与します。
  • (廃止)UTL_FILE_DIRシステム パラメータを使用します。これはシステム全体のパラメータであり、すべてのユーザーがこのディレクトリを読み書きできることに注意してください。
于 2011-03-01T10:00:13.327 に答える
0

最初に Oracle DIRECTORY オブジェクトを作成してからfopen、ファイルシステム パスを渡す代わりに、への呼び出しでそのオブジェクトを参照する必要があります。

詳細: http://www.orafaq.com/wiki/Oracle_directory

于 2011-03-01T10:47:47.157 に答える
0

UTL_FILE に関係することはすべて、クライアントではなくデータベース サーバーで発生します。ディレクトリがサーバー上に存在すること、および Oracle ユーザーがそのディレクトリへの書き込み権限を持っていることを確認してください。

于 2011-03-01T22:42:09.250 に答える