1 UTL_FILE_DIR参数定义

UTL_FILE_DIR是Oracle中的一个“静态参数”,可以设置一个或多个路径。用于在PL/SQL中进行文件I/O操作(可以用utl_file包)时指定路径。UTL_FILE_DIR是Oracle中的一个“静态参数”,可以设置一个或多个路径。用于在PL/SQL中进行文件I/O操作(可以用utl_file包)时限定路径,utl_file包只能在指定路径下创建,读取文件。utl_file_dir为空时,则不限定路径。

2 UTL_FILE包简介

在PL/SQL中没有直接的文件I/O接口,一般在调试程序时可以使用Oracle自带的DBMS_OUTPUT包的put_line函数(即向屏幕进行I/O 操作),但是不能对磁盘文件进行I/O操作。文件I/O对于数据库的开发来说显得很重要,比如如果数据库中的一部分数据来自于磁盘文件,那么就需要使用I/O接口把数据导入到数据库中来。

3 实验

3.1 设置utl_file_dir参数

SQL> alter system set utl_file_dir='/u01/app/oracle' scope=spfile;

System altered.

SQL> startup force;

SQL> show parameter utl_file

NAME                                 TYPE       VALUE

-------------------------------- ----------- ------------------------------

utl_file_dir                         string      /u01/app/oracle

设置多个路径:

SQL> alter system set utl_file_dir='/u01/app/oracle', '/oradata' scope=spfile;

System altered.

SQL> startup force

NAME                                 TYPE      VALUE

-------------------------------- ----------- ------------------------------

utl_file_dir                         string      /u01/app/oracle, /oradata

3.2 utl_file的IO操作

SQL> declare

fn utl_file.file_type;

begin

fn := utl_file.fopen('/u01/app/oracle', 'utl_test.txt', 'W');

utl_file.fclose(fn);

end;

/

PL/SQL procedure successfully completed.

不是utl_file_dir所指定的路径时,使用fopen方法时就会报错:

SQL> declare

fn utl_file.file_type;

begin

fn := utl_file.fopen('/u01/app/oracle/admin', 'utl_test.txt', 'W');

utl_file.fclose(fn);

end;

/

declare

*

ERROR at line 1:

ORA-29280: invalid directory path

ORA-06512: at "SYS.UTL_FILE", line 33

ORA-06512: at "SYS.UTL_FILE", line 436

ORA-06512: at line 4

为了避免上面的错误,可以使用路径对象。

SQL> create directory dir_test as '/oradata';

Directory created.

SQL> declare

fn utl_file.file_type;

begin

fn := utl_file.fopen('DIR_TEST', 'test.txt', 'W');

utl_file.fclose(fn);

end;

最新文章

  1. ASP.NET Aries 开源开发框架:开发指南(一)
  2. 解决IntelliJ IDEA无法读取配置文件的问题
  3. IIS事件查看器_WebServer事件查看器_帮助查看IIS-Web服务器事件执行日志
  4. slf4j介绍以及实现原理窥探
  5. Bootstrap左侧下拉三级菜单
  6. Python学习笔记2—内置函数
  7. 高达渐出现效果Shader
  8. Photoshop:制作金属质感-不锈钢纹理
  9. Service通信详解
  10. iOS 开发 上传代码至github(转)
  11. hibernate - Transaction not successfully started
  12. Snake - SGU 128(构造多边形)
  13. struts2学生信息管理系统篇章④
  14. -_-#【Canvas】
  15. 制作EDM 邮件规范
  16. 关于hashCode与equals
  17. 不使用synchronized和lock 锁实现线程安全单例
  18. [Swift]LeetCode506. 相对名次 | Relative Ranks
  19. Scrapy 框架,持久化文件相关
  20. Ubuntu14.04 安装 Sublime Text 3

热门文章

  1. linux内存监控 free
  2. Alternative to iPhone device ID (UDID)
  3. NSStream文件流
  4. java中容器的概念
  5. python 时间相关函数
  6. django-redis 使用规范
  7. 【BZOJ4555】[TJOI&HEOI2016]求和 斯特林数+NTT
  8. 线性可分SVM完全推导过程
  9. 洛谷 P2096 最佳旅游线路
  10. c语言数据结构学习心得——树