Oracle外部表使用一例

在Oracle 9i中,sqlldr增加了一个新的参数external_table。通过这个参数的generate_only选项,可以生成完整的外部表创建语句。

现在有一个sqlldr控制文件,内容如下:

 

load data
infile 'd:\sqldr\test.txt'
badfile 'd:\sqldr\test.bad'
discardfile 'd:\sqldr\test.dis'
append into table test
fields terminated by X'09'
trailing nullcols
(
id,
name
)

 

利用如下命令行生成完整的外部表创建语句:

C:\>sqlldr test/test@acf control=d:\sqldr\test.ctl  external_table=generate_only

 

在c:\根目录下找到test.log文件,这个文件包括了非常详细的内容,找到相应部分

 

用于外部表的 CREATE TABLE 语句:
------------------------------------------------------------------------
CREATE TABLE "SYS_SQLLDR_X_EXT_TEST"
(
  "ID" NUMBER(38),
  "NAME" VARCHAR2(10)
)
ORGANIZATION external
(
  TYPE oracle_loader
  DEFAULT DIRECTORY TEST_DIR
  ACCESS PARAMETERS
  (
    RECORDS DELIMITED BY NEWLINE CHARACTERSET ZHS16GBK
    BADFILE 'TEST_DIR':'test.bad'
    DISCARDFILE 'TEST_DIR':'test.dis'
    LOGFILE 'test.log_xt'                                    /*注意:这几个文件的路径不能有绝对路径,否则会抱错*/
    READSIZE 1048576
    FIELDS TERMINATED BY 0x'09' LDRTRIM
    MISSING FIELD VALUES ARE NULL
    REJECT ROWS WITH ALL NULL FIELDS
    (
      "ID" CHAR(255)
        TERMINATED BY 0x'09',
      "NAME" CHAR(255)
        TERMINATED BY 0x'09'
    )
  )
  location
  (
    'test.txt'
  )
)REJECT LIMIT UNLIMITED

 

 

这样就可以利用生成的语句创建外部表,运行上面的语句创建外部表

 

运行查询外部表以验证外部表创建是否成功!

select * from "SYS_SQLLDR_X_EXT_TEST"

结果如下:

ID NAME
1 a
2 b
3 c
4 d
5 e
6 f

 

至此,外部表创建完毕!!!

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值