您的位置:首页 > 数据库 > Oracle

Oracle EBS服务器目录配置

2014-09-25 20:44 197 查看

服务器目录配置

1、创建服务器目录
(1)在system用户下执行如下命令:CREATE OR REPLACE DIRECTORY MAIL_FILE_DIR AS '/mail_file/data/PROD';
(2)给创建的目录赋权限,执行:GRANT read ,write ON DIRECTORY MAIL_FILE_DIR TO PUBLIC;
如果是双节点的服务器,在两个服务器上执行上述sql语句

2、在数据库服务器上创建/mail_file/data/PROD目录
切换到主目录'/'下执行创建目录命令
目录创建完成后在主目录'/'下执行赋权限命令:chmod 777 /mail_file/data/PROD

3、向目录下写入文件
[align=left]DECLARE[/align]
[align=left]  fhandle utl_file.file_type;[/align]
[align=left]BEGIN[/align]
[align=left]  fhandle := utl_file.fopen( 'MAIL_FILE_DIR', 'example.txt' , 'w');[/align]
  utl_file.put_line(fhandle, 'gh
test write one');
  utl_file.put_line(fhandle, 'gh
test write two');
[align=left]  utl_file.fclose(fhandle);[/align]
[align=left]END;[/align]
[align=left]
[/align]
[align=left]4、读出文件的内容[/align]

[align=left]DECLARE[/align]
[align=left]  fhandle   utl_file.file_type;[/align]
[align=left]  fp_buffer VARCHAR2( 4000);[/align]
[align=left]BEGIN[/align]
[align=left]  fhandle := utl_file.fopen( 'MAIL_FILE_DIR', 'example.txt' , 'R');[/align]
[align=left]
[/align]
[align=left]  utl_file.get_line(fhandle, fp_buffer);[/align]
[align=left]  dbms_output.put_line(fp_buffer);[/align]
[align=left]  utl_file.get_line(fhandle, fp_buffer);[/align]
[align=left]  dbms_output.put_line(fp_buffer);[/align]
[align=left]  utl_file.fclose(fhandle);[/align]
[align=left]END;[/align]
[align=left]
[/align]
[align=left]报错:[/align]

ORA-29283 :
文件操作无效
ORA-06512 :
在"SYS.UTL_FILE", line 449
ORA-29283 :
文件操作无效
[align=left]原因:在数据库下面没有目录或者目录没有赋读写权限[/align]
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息