SQL LOADER ORA-01722 [message #631143] |
Fri, 09 January 2015 12:47 data:image/s3,"s3://crabby-images/3bcce/3bcce7084f96de28f8958fb8ba64988a13b0e75a" alt="Go to next message Go to next message" |
data:image/s3,"s3://crabby-images/9f265/9f26537d912de487d6daafe3486a25d2967f0708" alt="" |
danielortiz82
Messages: 6 Registered: January 2015
|
Junior Member |
|
|
hi,
Im trying to figure out why SQLLDR is sending this log error message:
Record 1: Rejected - Error on table TU_CATEGORIA_CITA, column LIMITE_CITAS.
ORA-01722: Number not valid
My ctl file is:
LOAD DATA
INFILE tu_categoria_cita.txt'
APPEND
INTO TABLE TU_CATEGORIA_CITA
FIELDS TERMINATED BY ','
OPTIONALLY ENCLOSED BY '"' TRAILING NULLCOLS
(
CVE_CATEGORIA_CITA,
DESCRIPCION,
LIMITE_CITAS
)
and the txt file is like this:
"1","Inicio",1
"2","Seguimiento",80
"3","Cierre",1
In the DB the table columns datatypes are varchar(2 bytes), varchar(40 bytes) and number(2,0) for the three fields
Thanks in advance!
|
|
|
|
|
|
Re: SQL LOADER ORA-01722 [message #631153 is a reply to message #631143] |
Fri, 09 January 2015 14:24 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/a38b1/a38b1298f0579d3db40ae01cecbdd08376fa4990" alt="" |
LKBrwn_DBA
Messages: 487 Registered: July 2003 Location: WPB, FL
|
Senior Member |
|
|
Your control file works for me:
SQL*Loader: Release 11.2.0.3.0 - Production on Fri Jan 9 15:21:49 2015
Copyright (c) 1982, 2011, Oracle and/or its affiliates. All rights reserved.
Control File: test.ctl
Data File: test.ctl
Bad File: test.bad
Discard File: none specified
(Allow all discards)
Number to load: ALL
Number to skip: 0
Errors allowed: 50
Bind array: 64 rows, maximum of 256000 bytes
Continuation: none specified
Path used: Conventional
Table SCOTT.TU_CATEGORIA_CITA, loaded from every logical record.
Insert option in effect for this table: TRUNCATE
TRAILING NULLCOLS option in effect
Column Name Position Len Term Encl Datatype
------------------------------ ---------- ----- ---- ---- ---------------------
CVE_CATEGORIA_CITA FIRST * , O(") CHARACTER
DESCRIPCION NEXT * , O(") CHARACTER
LIMITE_CITAS NEXT * , O(") CHARACTER
Table SCOTT.TU_CATEGORIA_CITA:
3 Rows successfully loaded.
0 Rows not loaded due to data errors.
0 Rows not loaded because all WHEN clauses were failed.
0 Rows not loaded because all fields were null.
Space allocated for bind array: 49536 bytes(64 rows)
Read buffer bytes: 1048576
Total logical records skipped: 0
Total logical records read: 3
Total logical records rejected: 0
Total logical records discarded: 0
[3eyes]
[Updated on: Fri, 09 January 2015 14:24] Report message to a moderator
|
|
|
|
|
|
Re: SQL LOADER ORA-01722 [message #631168 is a reply to message #631153] |
Fri, 09 January 2015 15:49 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/9f265/9f26537d912de487d6daafe3486a25d2967f0708" alt="" |
danielortiz82
Messages: 6 Registered: January 2015
|
Junior Member |
|
|
LKBrwn_DBA wrote on Fri, 09 January 2015 14:24Your control file works for me:
SQL*Loader: Release 11.2.0.3.0 - Production on Fri Jan 9 15:21:49 2015
Copyright (c) 1982, 2011, Oracle and/or its affiliates. All rights reserved.
Control File: test.ctl
Data File: test.ctl
Bad File: test.bad
Discard File: none specified
(Allow all discards)
Number to load: ALL
Number to skip: 0
Errors allowed: 50
Bind array: 64 rows, maximum of 256000 bytes
Continuation: none specified
Path used: Conventional
Table SCOTT.TU_CATEGORIA_CITA, loaded from every logical record.
Insert option in effect for this table: TRUNCATE
TRAILING NULLCOLS option in effect
Column Name Position Len Term Encl Datatype
------------------------------ ---------- ----- ---- ---- ---------------------
CVE_CATEGORIA_CITA FIRST * , O(") CHARACTER
DESCRIPCION NEXT * , O(") CHARACTER
LIMITE_CITAS NEXT * , O(") CHARACTER
Table SCOTT.TU_CATEGORIA_CITA:
3 Rows successfully loaded.
0 Rows not loaded due to data errors.
0 Rows not loaded because all WHEN clauses were failed.
0 Rows not loaded because all fields were null.
Space allocated for bind array: 49536 bytes(64 rows)
Read buffer bytes: 1048576
Total logical records skipped: 0
Total logical records read: 3
Total logical records rejected: 0
Total logical records discarded: 0
[3eyes]
I guess it should work...
the only thing I can think of you might have different is that the table has an extra date field which has a default to SYSDATE, but I dont think that changes anything in the issue
thanks
|
|
|
|
|
|
Re: SQL LOADER ORA-01722 [message #631176 is a reply to message #631147] |
Fri, 09 January 2015 22:18 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" |
flyboy
Messages: 1903 Registered: November 2006
|
Senior Member |
|
|
danielortiz82 wrote on Fri, 09 January 2015 20:15Any ideas? Do I need to use "terminated by (some kind of end-of-line command)"?
Just a wild guess, as your post lacks that information (OS on database system and sqlldr, exact file content), anyway,
I also faced the same error when loading file with DOS line break (CR+LF) to Oracle database on Linux system.
Solution was applying dos2unix utility to the loaded file; its creation having the same line break format as the Oracle database would be fine too.
[Edit: added the last sentence]
[Updated on: Fri, 09 January 2015 22:22] Report message to a moderator
|
|
|
Re: SQL LOADER ORA-01722 [message #631181 is a reply to message #631176] |
Fri, 09 January 2015 23:19 data:image/s3,"s3://crabby-images/5d024/5d02489f93cb86dd1a658de391c37413cb5e3f44" alt="Go to previous message Go to previous message" |
data:image/s3,"s3://crabby-images/acc29/acc29ddc029daa9b975a87ffd5d807885f015c0d" alt="" |
Barbara Boehmer
Messages: 9104 Registered: November 2002 Location: California, USA
|
Senior Member |
|
|
Flyboy is right. This is a common problem when data from one operating system with one line terminator is loaded onto another operating system with a different line terminator. The fact that you only have a problem when the numeric field is last is proof that the terminator is the problem. There are various ways to work around this problem. You can generate the data file differently or convert the data file. You can also trim the extra characters within SQL*Loader or declare the terminator separately for that field.
|
|
|