7

使用 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 表中。我的解决方案是将这个控制文件分成两个单独的文件。有什么方法可以遵守一个控制文件?

4

2 回答 2

7

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

控制文件:

OPTIONS(skip=1,bindsize=1048576,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 可能会更好。

于 2011-07-01T09:16:48.187 回答
0

我只是使用 WHEN 子句跳过标题
我将使用 column1 的列名作为示例
column1_DB 是数据库中的列名, column1_CSV 是 csv 文件中的列名,
如果您确定没有column1 中的值将与列标题相同,如果是这种情况,您可以选择任何其他列,您可以确定这些值永远不会与标题匹配。

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
WHEN column1_DB <> 'column1_CSV'
FIELDS TERMINATED BY ',' OPTIONALLY ENCLOSED BY '"'  TRAILING NULLCOLS
(
column1_DB CHAR(4000),
column2_DB CHAR(4000)
)
于 2020-08-04T16:19:05.400 回答