使用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表中。我的解决方案是将此控制文件分成两个单独的文件。有没有办法遵守一个控制文件?
答案 0 :(得分:6)
你可以使用一个控制文件,但它仍然需要你运行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可能会更好。
答案 1 :(得分: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)
)