多个infiles的Oracle Sql Loader跳过选项

前端之家收集整理的这篇文章主要介绍了多个infiles的Oracle Sql Loader跳过选项前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
使用sql Loader控制文件时如下:

OPTIONS(**skip=1**,bindsize=1048576,rows=1024)
LOAD DATA
INFILE 'C:\Documents and Settings\FIRST.CSV'
INFILE 'C:\Documents and Settings\SECOND.CSV'
APPEND
INTO TABLE table_name
FIELDS TERMINATED BY ',' OPTIONALLY ENCLOSED BY '"'  TRAILING NULLCOLS
(
fields
)

它会跳过FIRST.CSV文件标题行,但会将SECOND.CSV中的标题行加载到Oracle表中.我的解决方案是将此控制文件分成两个单独的文件.有没有办法遵守一个控制文件

解决方法

您可以使用一个控制文件,但它仍然需要您运行sqlldr两次:

控制文件

OPTIONS(skip=1,rows=1024)
LOAD DATA
APPEND
INTO TABLE table_name
FIELDS TERMINATED BY ',' OPTIONALLY ENCLOSED BY '"' TRAILING NULLCOLS
(
  fields
)

然后像这样运行sqlldr:

sqlldr control=control.ctl data=FIRST.CSV
sqlldr control=control.ctl data=SECOND.CSV

我刚刚遇到的另一个选择是你可以使用WHEN子句检查记录:

OPTIONS(bindsize=1048576,rows=1024)
LOAD DATA
INFILE 'C:\Documents and Settings\FIRST.CSV'
INFILE 'C:\Documents and Settings\SECOND.CSV'
APPEND
INTO TABLE table_name
WHEN (field1 <> 'ContentsOfField1InHeaderRow')
FIELDS TERMINATED BY ',' OPTIONALLY ENCLOSED BY '"' TRAILING NULLCOLS
(
  fields
)

如果标题始终包含固定文本,则可以根据(其中一个)字段的内容跳过它.使用WHEN可能会对性能产生影响 – 根据文件的大小,通过两次调用sqlldr可能会更好.

猜你在找的Oracle相关文章