Concatenating dashes in a column using sqlldr [message #508379] |
Fri, 20 May 2011 13:17 data:image/s3,"s3://crabby-images/3bcce/3bcce7084f96de28f8958fb8ba64988a13b0e75a" alt="Go to next message Go to next message" |
rappaj
Messages: 147 Registered: June 2010 Location: NYC
|
Senior Member |
|
|
Hi,
I'd like to load ss_numbers, but concatenate dashes in between.
The ssn currently looks like this in the file: 123456789
I'd like to put dashes in there to make it load like this.
123-45-6789
The data is positional, so I have the column in the ctl file defined as:
ssn position(1:9) char nullif ssn=blanks ,
I know how to concat using the other method of loading this way, but this is not how the data file looks:
"substr(lpad(:ssn,9,'0'),1,3)||'-'||substr(lpad(:ssn,9,'0'),4,2) ||'-'||substr(lpad(:ssn,9,'0'),6,4)",
Can someone please show me how to get the dashes in there while loading with the positional method?
Thanks
|
|
|
|
|
Re: Concatenating dashes in a column using sqlldr [message #508401 is a reply to message #508381] |
Fri, 20 May 2011 17:09 data:image/s3,"s3://crabby-images/5d024/5d02489f93cb86dd1a658de391c37413cb5e3f44" alt="Go to previous message Go to previous message" data:image/s3,"s3://crabby-images/3bcce/3bcce7084f96de28f8958fb8ba64988a13b0e75a" alt="Go to next message Go to next message" |
data:image/s3,"s3://crabby-images/acc29/acc29ddc029daa9b975a87ffd5d807885f015c0d" alt="" |
Barbara Boehmer
Messages: 9104 Registered: November 2002 Location: California, USA
|
Senior Member |
|
|
It should not make any difference. You should be able to treat positional data, as shown below, the same as delimited data.
-- test.dat:
123456789 aa
987654321 cc
-- test.ctl:
load data
infile test.dat
into table test_tab
fields
(ssn position(1:9) char nullif ssn=blanks "substr(lpad(:ssn,9,'0'),1,3)||'-'||substr(lpad(:ssn,9,'0'),4,2) ||'-'||substr(lpad(:ssn,9,'0'),6,4)",
other position(11:12) char)
-- table, load, and results:
SCOTT@orcl_11gR2> create table test_tab
2 (ssn varchar2 (11),
3 other varchar2 (2))
4 /
Table created.
SCOTT@orcl_11gR2> host sqlldr scott/tiger control=test.ctl log=test.log
SCOTT@orcl_11gR2> select * from test_tab
2 /
SSN OT
----------- --
123-45-6789 aa
987-65-4321 cc
2 rows selected.
SCOTT@orcl_11gR2>
|
|
|
|