• Oracle utl_file_dir参数详解


    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;

  • 相关阅读:
    06-图2 Saving James Bond
    06-图3 六度空间 (30 分)
    07-图5 Saving James Bond
    09-排序3 Insertion or Heap Sort (25 分)
    09-排序2 Insert or Merge (25 分)
    10-排序4 统计工龄 (20 分)
    10-排序5 PAT Judge (25 分)
    使用正则表达式验证汉字输入
    使用正则表达式验证字母
    使用正则表达式对字符串进行拆分
  • 原文地址:https://www.cnblogs.com/pekkle/p/6568779.html
Copyright © 2020-2023  润新知