我想使用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
(...
)
答案 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