0

每当我将预处理器子句添加到我的外部表语句中时,我似乎遇到了问题。如果没有预处理器行,它一切正常,但是一旦我添加它,我就会得到各种错误,具体取决于我将它放在访问参数块中的位置,它们是否必须按特定顺序排列?我在网上找不到任何类似的问题。

编辑:另外作为旁注,我知道您可以使用预处理器将压缩文件提供给外部表。如果我想读取一个压缩文件并附加文件名,是否就像把它全部放在一个 shell 文件中一样简单?

CREATE TABLE (
    column1 VARCHAR2(40),
    column2 VARCHAR2(40)
)
ORGANIZATION EXTERNAL
(
  TYPE ORACLE_LOADER
  DEFAULT DIRECTORY DMPDIR
    ACCESS PARAMETERS(
        RECORDS DELIMITED BY NEWLINE
        LOGFILE DMPDIR:'test.log'
        BADFILE DMPDIR:'test.bad'
        fields terminated by '^'
        MISSING FIELD VALUES ARE NULL
        REJECT ROWS WITH ALL NULL FIELDS
        preprocessor DMPDIR: 'append_filename.sh'
    )
 LOCATION (DMPDIR: 'testfile.dat')
);

附加文件名.sh

#!/bin/bash
sed -e 's!$!,'"${1##*/}"'!' $1
4

1 回答 1

2

这是一个external table使用PREPROCESSOR创建的小示例。我在 12c 上做了这个:

SQL> select banner from v$version where rownum = 1;

BANNER
----------------------------------------------------------------------------
Oracle Database 12c Enterprise Edition Release 12.1.0.1.0 - 64bit Production

SQL> DROP TABLE validation_header;

Table dropped.

SQL>
SQL> CREATE TABLE validation_header (
  2  header1 VARCHAR2(5),
  3  header2 number,
  4  header3 VARCHAR2(8),
  5  header4 number
  6  )
  7  ORGANIZATION EXTERNAL (
  8  TYPE oracle_loader
  9  DEFAULT DIRECTORY data_pump_dir
 10  ACCESS PARAMETERS (
 11  RECORDS DELIMITED BY NEWLINE
 12  PREPROCESSOR import_ppm:'script.ksh'
 13  LOGFILE import_ppm:'script.log'
 14  FIELDS TERMINATED BY ','
 15  (header1,header2,header3, header4
 16  ))
 17  LOCATION ('script_file.txt')
 18  );

Table created.

SQL>

从文档中,

KUP-04094:如果安装了 Database Vault,则无法执行预处理

  • 原因:Database Vault 选项不允许从 Oracle 目录对象执行程序。

  • 操作:如果必须执行预处理,则不得安装 Database Vault 选项。

于 2015-03-25T11:19:56.070 回答