Oracle外部表:高级平面文件布局

时间:2009-05-22 16:55:33

标签: oracle external sql-loader

我希望在Oracle数据库中创建一个外部表,从服务器上的平面文件中检索其数据。这个文件的格式非常重要。此文件中的每一行可以是几种不同布局中的一种,具体取决于行的前缀(前缀本身始终是固定长度)。例如,以'TYPE1'开头的行的布局与以'TYPE2'开头的行不同。

我已经读过外部表可以利用SQL Loader的控制文件可用的所有构造。但是,我读过的任何文档只能处理琐碎的平面文件布局,所有行共享一个共同的布局。 SQL Loader控制文件可以使用WHEN子句轻松处理此场景:

WHEN (1:5) = 'TYPE1'
(
    field1 POSITION(10:18),
    field2 POSITION(26:35)
)
WHEN (1:5) = 'TYPE2'
(
    field1 POSITION(23:27),
    field2 POSITION(15:19)
)

如何使用Oracle的外部表定义语法表达这样的布局?

2 个答案:

答案 0 :(得分:1)

这是来自9.2文档,但您需要LOAD WHEN子句。

http://download.oracle.com/docs/cd/B10500_01/server.920/a96652/ch12.htm

答案 1 :(得分:0)

如果您有固定记录,请尝试此

create table EXT_TABLE
(
  record_type        char(2),
  customer_id        char(10),
  customer_name      char(60),
  item_id            char(12)
  quantity           char(10)
)
organization external
(
  type ORACLE_LOADER
  default directory DIR_FLUX_DEV
  access parameters
  (
    RECORDS DELIMITED BY NEWLINE
     BADFILE 'ext_table.bad'
     LOGFILE 'ext_table.log'
     SKIP 0
     FIELDS
    (
     TP_REC               position(1:2)   char(2),
     customer_id          position(3:10)  char(10),
     customer_name        position(13:60) char(60),
     item_id              position(3:12)  char(12),
     quantity             position(15:10) char(10)
    )
  )
  location (DIR_FLUX_DEV:'file.txt')
)
reject limit 0;

然后您可以根据记录类型访问then列 宣布   光标c1是

select e.* from ext_table;

begin
  for r in c1 loop
    if r.tp_rec = '02' then
       dbms_output.put_line(r.tp_rec || ' ' || r.customer_id);
    elsif r.tp_rec = '03' then
       dbms_output.put_line(r.tp_rec || ' ' || r.item_id);
    end if;
  end loop;
end;

希望这有帮助