多个infiles的Oracle Sql Loader跳过选项

多个infiles的Oracle Sql Loader跳过选项,第1张

概述使用SQL Loader控制文件时如下: OPTIONS(**skip=1**,bindsize=1048576,rows=1024)LOAD DATAINFILE 'C:\Documents and Settings\FIRST.CSV'INFILE 'C:\Documents and Settings\SECOND.CSV'APPENDINTO TABLE table_nameFI 使用sql Loader控制文件时如下:

OPTIONS(**skip=1**,bindsize=1048576,rows=1024)LOAD DATAINfile 'C:\documents and Settings\FirsT.CSV'INfile 'C:\documents and Settings\SECOND.CSV'APPENDINTO table table_nameFIELDS TERMINATED BY ',' OPTIONALLY ENCLOSED BY '"'  TRAIliNG NulLColS(fIElds)

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

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

控制文件:

OPTIONS(skip=1,rows=1024)LOAD DATAAPPENDINTO table table_nameFIELDS TERMINATED BY ',' OPTIONALLY ENCLOSED BY '"' TRAIliNG NulLColS(  fIElds)

然后像这样运行sqlldr:

sqlldr control=control.ctl data=FirsT.CSVsqlldr control=control.ctl data=SECOND.CSV

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

OPTIONS(bindsize=1048576,rows=1024)LOAD DATAINfile 'C:\documents and Settings\FirsT.CSV'INfile 'C:\documents and Settings\SECOND.CSV'APPENDINTO table table_nameWHEN (fIEld1 <> 'ContentsOfFIEld1InheaderRow')FIELDS TERMINATED BY ',' OPTIONALLY ENCLOSED BY '"' TRAIliNG NulLColS(  fIElds)

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

总结

以上是内存溢出为你收集整理的多个infiles的Oracle Sql Loader跳过选项全部内容,希望文章能够帮你解决多个infiles的Oracle Sql Loader跳过选项所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/sjk/1165839.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-06-01
下一篇 2022-06-01

发表评论

登录后才能评论

评论列表(0条)

保存