多个infiles的Oracle Sql Loader跳过选项
发布时间:2021-03-06 06:04:25 所属栏目:百科 来源:网络整理
导读:使用SQL Loader控制文件时如下: OPTIONS(**skip=1**,bindsize=1048576,rows=1024)LOAD DATAINFILE 'C:Documents and SettingsFIRST.CSV'INFILE 'C:Documents and SettingsSECOND.CSV'APPENDINTO TABLE table_nameFIELDS TERMINATED BY ',' OPTIONALLY
使用SQL Loader控制文件时如下: OPTIONS(**skip=1**,bindsize=1048576,rows=1024) LOAD DATA INFILE 'C:Documents and SettingsFIRST.CSV' INFILE 'C:Documents and SettingsSECOND.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 SettingsFIRST.CSV' INFILE 'C:Documents and SettingsSECOND.CSV' APPEND INTO TABLE table_name WHEN (field1 <> 'ContentsOfField1InHeaderRow') FIELDS TERMINATED BY ',' OPTIONALLY ENCLOSED BY '"' TRAILING NULLCOLS ( fields ) 如果标题始终包含固定文本,则可以根据(其中一个)字段的内容跳过它.使用WHEN可能会对性能产生影响 – 根据文件的大小,通过两次调用sqlldr可能会更好. (编辑:淮北站长网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |