【问题标题】:Oracle Sql Loader skip option for multiple infiles用于多个 infile 的 Oracle Sql Loader 跳过选项
【发布时间】:2011-06-29 13:42:05
【问题描述】:

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

【问题讨论】:

    标签: oracle sql-loader


    【解决方案1】:

    您可以使用一个控制文件,但仍然需要您运行 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 可能会更好。

    【讨论】:

      【解决方案2】:

      我只是使用了一个 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)
      )
      

      【讨论】:

        猜你喜欢
        • 1970-01-01
        • 1970-01-01
        • 2012-02-15
        • 1970-01-01
        • 1970-01-01
        • 2015-03-11
        • 2019-09-21
        • 2010-10-15
        相关资源
        最近更新 更多