oracle directory 目录 -凯发k8网页登录

posts - 310, comments - 6939, trackbacks - 0, articles - 3
  凯发k8网页登录-凯发天生赢家一触即发官网 :: 凯发k8网页登录首页 :: 新随笔 :: 联系 :: 聚合  :: 管理
posted on 2009-01-10 11:48 诗特林 阅读(34976) 评论(3)     所属分类: oracle
create directory让我们可以在oracle数据库中灵活的对文件进行读写操作,极大的提高了oracle的易用性和可扩展性。
其语法为:
create [or replace] directory directory as 'pathname';

本案例具体创建如下:

create or replace directory exp_dir as '/tmp';

目录创建以后,就可以把读写权限授予特定用户,具体语法如下:
grant read[,write] on directory directory to username;

例如:

grant read, write on directory exp_dir to eygle;

此时用户eygle就拥有了对该目录的读写权限。

让我们看一个简单的测试:

sql> create or replace directory utl_file_dir as '/opt/oracle/utl_file'; directory created. sql> declare 2 fhandle utl_file.file_type; 3 begin 4 fhandle := utl_file.fopen('utl_file_dir', 'example.txt', 'w'); 5 utl_file.put_line(fhandle , 'eygle test write one'); 6 utl_file.put_line(fhandle , 'eygle test write two'); 7 utl_file.fclose(fhandle); 8 end; 9 / pl/sql procedure successfully completed. sql> ! [oracle@jumper 9.2.0]$ more /opt/oracle/utl_file/example.txt eygle test write one eygle test write two [oracle@jumper 9.2.0]$

类似的我们可以通过utl_file来读取文件:

sql> declare 2 fhandle utl_file.file_type; 3 fp_buffer varchar2(4000); 4 begin 5 fhandle := utl_file.fopen ('utl_file_dir','example.txt', 'r'); 6 7 utl_file.get_line (fhandle , fp_buffer ); 8 dbms_output.put_line(fp_buffer ); 9 utl_file.get_line (fhandle , fp_buffer ); 10 dbms_output.put_line(fp_buffer ); 11 utl_file.fclose(fhandle); 12 end; 13 / eygle test write one eygle test write two pl/sql procedure successfully completed.

可以查询dba_directories查看所有directory.

sql> select * from dba_directories; owner directory_name directory_path ------------------------------ ------------------------------ ------------------------------ sys utl_file_dir /opt/oracle/utl_file sys bdump_dir /opt/oracle/admin/conner/bdump sys exp_dir /opt/oracle/utl_file

可以使用drop directory删除这些路径.

sql> drop directory exp_dir; directory dropped sql> select * from dba_directories; owner directory_name directory_path ------------------------------ ------------------------------ ------------------------------ sys utl_file_dir /opt/oracle/utl_file sys bdump_dir /opt/oracle/admin/conner/bdump


评论

# re: oracle directory 目录  回复     

2009-01-13 12:54 by 隔叶黄莺
oracle 中确实是还有许多可挖掘的东西,比如 queue、java sources、job、dblink、synonym、type、cluster 等。

directory 的用法先给自己在脑子里留个记,现暂时还没想到有什么实际的用途,以后我想应该会派上用场的。

# re: oracle directory 目录  回复     

2010-05-21 16:02 by
备份的时候,你就要用了

# re: oracle directory 目录  回复     

2017-12-14 11:09 by
备份中使用到了,加油研究

只有注册用户后才能发表评论。


网站导航:
              
相关文章:
 
网站地图