加入收藏 | 设为首页 | 会员中心 | 我要投稿 湖南网 (https://www.hunanwang.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长百科 > 正文

多个infiles的Oracle Sql Loader跳过选项

发布时间:2021-03-06 12:21:20 所属栏目:站长百科 来源:网络整理
导读:行使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 E

行使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也许会更好.

(编辑:湖南网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    热点阅读