7

表 T1 结构:col1 编号,col2 编号

表 T2 结构:col1 编号、col2 编号、col3 编号

.csv 文件:

row1:1,2,3,4,5,6
row2:1,2,3,4,5,6

我希望表 T1 中的数据为:

col1   col2
=====  ====
1       3
1       3

我希望表 T2 中的数据为:

col1   col2   col3
=====  ====   ==== 
1       3       5
1       3       5

以下控制文件不起作用

load data
infile *
insert into table T1 fields terminated by ',' TRAILING NULLCOLS 
(col1,fill1 filler,col2)
insert into table T2 fields terminated by ',' TRAILING NULLCOLS
(col1,fill2 filler,col2,fill3 filler,col3)
begindata
1,2,3,4,5,6
1,2,3,4,5,6

请帮我解决这个问题。

4

3 回答 3

2

这确实有效,但我不喜欢这个解决方案。在这些情况下,我更喜欢使用外部表。简短的回答是您遇到了问题,因为 SQLLDR 不会自动重新扫描多行导入的数据。以下是文档中的一个片段。

来自 SQLLDR 文档

将 POSITION 与多个表加载一起使用

在多表加载中,您指定多个 INTO TABLE 子句。当您为第一个表的第一列指定 POSITION( ) 时,位置是相对于逻辑记录的开头计算的。当您为后续表格的第一列指定 POSITION( ) 时,位置是相对于最后加载的表格的最后一列计算的。

因此,当后续的 INTO TABLE 子句开始时,位置不会自动设置为逻辑记录的开头。这允许多个 INTO TABLE 子句处理同一物理记录的不同部分。有关示例,请参阅提取多个逻辑记录。

逻辑记录可能包含两个表之一的数据,但不能同时包含两者。在这种情况下,您将重置 POSITION。对于 INTO TABLE 子句中的第一个字段,不要省略位置说明或使用 POSITION(*+n),而是使用 POSITION(1) 或 POSITION(n)。

    load data
    infile * 
    truncate
    into table T1 
    fields terminated by ',' trailing nullcols
    ( col1  
    , fill1 filler
    , col2  )
    into table T2 
    fields terminated by ','  trailing nullcols
    ( col1 position(1) 
    , filler filler
    , col2    
    , filler2 filler
    , col3 )   

BEGINDATA
1,2,3,4,5,6
1,2,3,4,5,6

SQL> select * From t1;

      COL1       COL2
---------- ----------
         1          3
         1          3

SQL> select* From t2;

      COL1       COL2       COL3
---------- ---------- ----------
         1          3          5
         1          3          5
于 2009-04-24T14:43:16.303 回答
2

尝试这个

LOAD DATA  
INFILE * "STR '|EndRec|'"  
INSERT INTO TABLE T1 FIELDS TERMINATED BY ',' TRAILING NULLCOLS 
(COL1, FILL2 FILLER, COL2, FILL4 FILLER, FILL5 FILLER, FILL6 FILLER)  
INSERT INTO TABLE T2 FIELDS TERMINATED BY ',' TRAILING NULLCOLS
(COL1 POSITION(1), FILL2 FILLER, COL2, FILL3 FILLER, COL3, FILL6 FILLER)

BEGINDATA  
1,2,3,4,5,6|EndRec|1,2,3,4,5,6|EndRec|
于 2010-12-13T09:14:34.253 回答
0

尝试这个:

LOAD DATA
INFILE *
INSERT INTO TABLE T1 FIELDS TERMINATED BY ',' TRAILING NULLCOLS 
(COL1, FILL2 FILLER, COL2, FILL4 FILLER, FILL5 FILLER, FILL6 FILLER)
INSERT INTO TABLE T2 FIELDS TERMINATED BY ',' TRAILING NULLCOLS
(COL1, FILL2 FILLER, COL2, FILL3 FILLER, COL3, FILL6 FILLER)
BEGINDATA
1,2,3,4,5,6
1,2,3,4,5,6
于 2009-04-01T12:35:41.547 回答