有条件导入 - 如何丢弃记录?

时间:2017-02-10 09:55:27

标签: oracle sql-loader

我想使用SQLLDR导入csv文件,但我只想要特定的记录。我在控制文件中用"WHEN record_type = 1"解决了这个问题。

这可以工作,但日志文件被“记录xxx:丢弃 - 所有WHEN条款都失败了。”输入文件包含数百万条记录,但只有百分之几满足条件,所以我最终得到一个与输入文件大小相同的日志文件:)

我做错了吗? 有没有其他方法可以在使用SQLLDR时丢弃/过滤记录?

示例数据:

record_type;a;b;c
24;a1;b1;c1
17;a2;b2;c2
22;an;bn;cn
1;a1;b1;c1
1;a2;b2;c2
1;an;bn;cn

控制文件

load data
truncate
into table my_table_t
WHEN record_type = 1
(...
)

3 个答案:

答案 0 :(得分:1)

你所做的是正确的IMO。

SQL * Loader正在为您记录最精细的加载详细信息。你可以选择退出一些事情。

Yo可以通过添加来禁用DISCARD记录日志记录 SILENT=(DISCARDS)

SQL*Loader

您可以参考DOC了解更多详情。

答案 1 :(得分:0)

如果您只想删除日志,可以将这些日志发送到/dev/null,如果您在Windows上使用Linux / Unix和NUL

实施例

数据文件。

[oracle@ora12c Desktop]$ cat sample.txt 
record_type;a;b;c
24;a1;b1;c1
17;a2;b2;c2
22;an;bn;cn
1;a1;b1;c1
1;a2;b2;c2
1;an;bn;cn

控制文件。

[oracle@ora12c Desktop]$ cat control.ctl 
load data
 infile 'sample.txt'
 insert
 into table table_1  when record_type = '1'
 fields terminated by ";"
 (record_type, a, b, c)

让我们尝试加载记录。

[oracle@ora12c Desktop]$ sqlldr jay/password@orapdb1 control=control.ctl data=sample.txt log=/dev/null

SQL*Loader: Release 12.1.0.2.0 - Production on Fri Feb 10 16:05:10 2017

Copyright (c) 1982, 2014, Oracle and/or its affiliates.  All rights reserved.

Path used:      Conventional
Commit point reached - logical record count 7

Table TABLE_1:
  3 Rows successfully loaded.

Check the log file:
  /dev/null
for more information about the load.

没有日志文件。

现在我们获得了唯一的选定记录。

SQL> select * from table_1;

RECORD_TYPE A            B            C
----------- -------------------- -------------------- --------------------
      1 a1           b1           c1
      1 a2           b2           c2
      1 an           bn           cn

答案 2 :(得分:0)

使用外部表,然后您可以使用简单的SQL来加载表...

insert into my_table_t( record_type, a, b, c )
select record_type, a, b, c 
from my_external_table
where record_type != 1