Posez votre question Signaler

SQL Loader erreur avec .nextval [Résolu]

Hellreaper - Dernière réponse le 26 févr. 2008 à 16:17
Bonjour,
Mon problème est que je n'arrive pas a importer mais ficher correctement,
Donc voici la table ke j'ai crée:
CREATE TABLE dmlres
(RESERVATION_ID NUMBER(6),
EMPLOYEE_ID NUMBER(6),
DATE_CREATION DATE,
TYPE_PAIEMENT VARCHAR2(30),
PRIX NUMBER(8,2),
ACHETEUR_ID NUMBER(6));
Voici mon ficher .ctl
LOAD DATA
INFILE 'C:\dmlres.csv'
TRUNCATE
INTO TABLE dmlres
FIELDS TERMINATED BY ';'
(RESERVATION_ID "db_seq.nextval" ,
EMPLOYEE_ID ,
DATE_CREATION,
TYPE_PAIEMENT,
PRIX ,
ACHETEUR_ID)
je crée ma sequence
CREATE SEQUENCE db_seq
START WITH 1
INCREMENT BY 1;
et je lance dans excuter cette commande:
sqlldr control=c:\dml_t_abo.ctl log=c:\log1.txt
Merci de me dire si vous trouver quelque chose de louche dans mon code merci,
Lire la suite 

SQL Loader erreur avec .nextval »

25 réponses
Réponse
+2
moins plus
ORA-01722:	invalid number
Cause:	The attempted conversion of a character string to a number failed because the character string was not a valid numeric literal. Only numeric fields or character fields containing numeric data may be used in arithmetic functions or expressions. Only numeric fields may be added to or subtracted from dates.
Action:	Check the character strings in the function or expression. Check that they contain only numbers, a sign, a decimal point, and the character "E" or "e" and retry the operation.


Sinon, ça se complique un peu, mais comme je n'ai pas d'oracle pour tester, je ne sais pas si l'on peut faire ça plus simplement:
LOAD DATA
INFILE 'C:\dmlres.csv'
TRUNCATE
INTO TABLE dmlres
WHEN PRIX<>'NULL'
FIELDS TERMINATED BY ';'
(RESERVATION_ID "db_seq.nextval" ,
EMPLOYEE_ID ,
DATE_CREATION,
TYPE_PAIEMENT,
PRIX CHAR "to_number(:PRIX,'9999999D99','NLS_NUMERIC_CHARACTERS= '',.''')",
ACHETEUR_ID)
INTO TABLE dmlres
WHEN PRIX='NULL'
FIELDS TERMINATED BY ';'
(RESERVATION_ID "db_seq.nextval" ,
EMPLOYEE_ID ,
DATE_CREATION,
TYPE_PAIEMENT,
PRIX,
ACHETEUR_ID)
En gros, si le prix n'est pas la chaine 'NULL', on applique la conversion, sinon, on le traite normalement...

Avec un peut de chance, ça passe... :)
asevereasevere - 26 févr. 2008 à 15:41
Content que ça fonctionne enfin pour toi! :)

Puis-je te demander une dernière requête (en espérant qu'elle ne soit pas fausse comme la dernière) afin d'aiguiller les autres utilisateurs qui auraient éventuellement le même problème que toi:
SELECT * FROM NLS_SESSION_PARAMETERS;


A plus
Hellreaper- 26 févr. 2008 à 15:58
voila pour ta dernière commande , dsl sa resemble a rien:

PARAMETER VALUE
NLS_LANGUAGE FRENCH
NLS_TERRITORY FRANCE
NLS_CURRENCY €
NLS_ISO_CURRENCY FRANCE
NLS_NUMERIC_CHARACTERS ,
NLS_CALENDAR GREGORIAN
NLS_DATE_FORMAT DD/MM/RR
NLS_DATE_LANGUAGE FRENCH
NLS_SORT FRENCH
NLS_TIME_FORMAT HH24:MI:SSXFF
NLS_TIMESTAMP_FORMAT DD/MM/RR HH24:MI:SSXFF
NLS_TIME_TZ_FORMAT HH24:MI:SSXFF TZR
NLS_TIMESTAMP_TZ_FORMAT DD/MM/RR HH24:MI:SSXFF TZR
NLS_DUAL_CURRENC Y €
NLS_COMP BINARY
NLS_LENGTH_SEMANTICS BYTE
NLS_NCHAR_CONV_EXCP F ALSE
asevere- 26 févr. 2008 à 16:17
Merci, c'est pile poil ce que je voulais :-)

A plus
Ajouter un commentaire
Réponse
+1
moins plus
Voilà, avec les logs c'est plus clair :)

Alors, tu as plusieur solution (au moins 4) sans toucher à ton ora.ini

Premièrement, ajouter un trigger after logon qui joue la requête suivante si le programme appelant est sqlloader/sqlloader.exe:
execute immediate 'alter session set nls_numeric_characters= ",."'

(Le programme appelant peut être récuperé entre autre par la requête suivante:
select program from v$session where audsid=sys_context('userenv','sessionid');)
Deuxièmement, modifier ton fichier source pour passer d'office les bonnes valeurs à sqlloader

Troisièmement, si tu es sous linux (pas testé sous windows qui est apparement ton environnement, avec l'équivalent de export via une console dos ça peut marcher...) setter la variable NLS_NUMERIC_CHARACTERS avant de lancer sqlloader, exemple:
$ export NLS_NUMERIC_CHARACTERS=",."
$ ta_commande_sqlloader
Quatrième solution (la plus adaptée à mon gout), corriger ton fichier de control (.ctl) comme suit:
LOAD DATA
INFILE 'C:\dmlres.csv'
TRUNCATE
INTO TABLE dmlres
FIELDS TERMINATED BY ';'
(RESERVATION_ID "db_seq.nextval" ,
EMPLOYEE_ID ,
DATE_CREATION,
TYPE_PAIEMENT,
PRIX CHAR "to_number(:PRIX,'9999999D99','NLS_NUMERIC_CHARACTERS= '',.''')",
ACHETEUR_ID)
Voilà! :)

Tiens nous au courant, et si ça ne passe pas, il nous faudrait une ligne de donnée pour voir et le NLS_NUMERIC_CHARACTERS de la base. (+plus les nouvelles logs)

@ plus
Ajouter un commentaire
Réponse
+0
moins plus
Bonjour,

Quel est le message d'erreur retourné par la commande ?
Ajouter un commentaire
Réponse
+0
moins plus
Voici le ficher de log mais je crois que mon erreur n'est pas le .nextval mais dans ma colonne prix car j'ai des prix avec des virgules.
or j'ai pour tant bien crée ma table non?


SQL*Loader: Release 10.2.0.1.0 - Production on Mar. Févr. 19 17:42:58 2008

Copyright (c) 1982, 2005, Oracle. All rights reserved.

Fichier de contrôle : c:\dml_t_abo.ctl
Fichier de données : C:\dmlres.csv
Fichier BAD : c:\dmlres.bad
Fichier DISCARD : aucune spécification

(Allouer tous les rebuts)

Nombre à charger : ALL
Nombre à sauter: 0
Erreurs permises: 50
Tableau de liens : 64 lignes, maximum de 256000 octets
Continuation : aucune spécification
Chemin utilisé: Classique

Table DMLRES, chargé à partir de chaque enregistrement physique.
Option d'insertion en vigueur pour cette table : TRUNCATE

Nom de colonne Position Long. Séparat. Encadrem. Type de données
------------------------------ ---------- ----- ---- ---- ---------------------
RESERVATION_ID FIRST * ; CHARACTER
chaîne SQL pour la colonne : "seq_t_reservations.nextval"
EMPLOYEE_ID NEXT * ; CHARACTER
DATE_CREATION NEXT * ; CHARACTER
TYPE_PAIEMENT NEXT * ; CHARACTER
PRIX NEXT * ; CHARACTER
ACHETEUR_ID NEXT * ; CHARACTER

Enregistrement 1 : Rejeté - Erreur sur table DMLRES, colonne PRIX.
ORA-01722: Nombre non valide
.....
Ajouter un commentaire
Réponse
+0
moins plus
Voici mon ficher dmlres.csv si sa peut vous aider pour m'aider a trouver quesque je fait de faux :
seq_t_reservations.nextval;9;05/11/2005;CB;289.2;1
seq_t_reservations.nextval;7;03/11/2005;Cheque;165.5;6
seq_t_reservations.nextval;4;29/10/2005;CB;588.4;23
seq_t_reservations.nextval;7;25/10/2005;Espece;257.4;57
seq_t_reservations.nextval;7;02/11/2005;CB;175;72
seq_t_reservations.nextval;7;23/10/2005;Cheque;225;65
seq_t_reservations.nextval;7;15/10/2005;Cheque;37.12;68
seq_t_reservations.nextval;3;05/11/2005;CB;948.64;60
seq_t_reservations.nextval;3;05/11/2005;Cheque;57;80
seq_t_reservations.nextval;11;05/11/2005;Cheque;202.5;67
seq_t_reservations.nextval;11;05/11/2005;CB;202.5;73
seq_t_reservations.nextval;12;05/11/2005;CB;214.5;62
Ajouter un commentaire
Réponse
+0
moins plus
Alors?

Le batch et toujours en train de tourner ? ou bien ? :)
Ajouter un commentaire
Réponse
+0
moins plus
Merci merci tu me sauve la vie!
Mais j'ai une nouvelle erreur car dans mon ficher .csv certain prix on une valeur NULL et donc voici mon nouveau ficher de log:
Ici l'erreur que j'ai si je comprend bien, c'est que je ne peut pas mettre une valeur NULL dans ma colone prix donc il faudrait que je fasse une contrainte sur ma table dmlres?

SQL*Loader: Release 10.2.0.1.0 - Production on Mer. Févr. 20 17:51:18 2008

Copyright (c) 1982, 2005, Oracle. All rights reserved.

Fichier de contrôle : c:\dml_t_abo.ctl
Fichier de données : C:\dmlres.csv
Fichier BAD : c:\dmlres.bad
Fichier DISCARD : aucune spécification

(Allouer tous les rebuts)

Nombre à charger : ALL
Nombre à sauter: 0
Erreurs permises: 50
Tableau de liens : 64 lignes, maximum de 256000 octets
Continuation : aucune spécification
Chemin utilisé: Classique

Table DMLRES, chargé à partir de chaque enregistrement physique.
Option d'insertion en vigueur pour cette table : TRUNCATE

Nom de colonne Position Long. Séparat. Encadrem. Type de données
------------------------------ ---------- ----- ---- ---- ---------------------
RESERVATION_ID FIRST * ; CHARACTER
chaîne SQL pour la colonne : "seq_t_reservations.nextval"
EMPLOYEE_ID NEXT * ; CHARACTER
DATE_CREATION NEXT * ; CHARACTER
TYPE_PAIEMENT NEXT * ; CHARACTER
PRIX NEXT * ; CHARACTER
chaîne SQL pour la colonne : "to_number(:PRIX,'9999999D99','NLS_NUMERIC_CHARACTERS= '',.''')"
ACHETEUR_ID NEXT * ; CHARACTER

Enregistrement 13 : Rejeté - Erreur sur table DMLRES, colonne PRIX.
ORA-01722: Nombre non valide

Enregistrement 18 : Rejeté - Erreur sur table DMLRES, colonne PRIX.
ORA-01722: Nombre non valide

Enregistrement 23 : Rejeté - Erreur sur table DMLRES, colonne PRIX.
ORA-01722: Nombre non valide

Enregistrement 31 : Rejeté - Erreur sur table DMLRES, colonne PRIX.
ORA-01722: Nombre non valide


Table DMLRES :
Chargement réussi de 37 Lignes.
4 Lignes chargement impossible dû à des erreurs de données.
0 Lignes chargement impossible car échec de toutes les clauses WHEN.
0 Lignes chargement impossible car tous les champs étaient non renseignés.


Espace affecté au tableau de liens : 99072 octets(64 lignes)
Octets de tampon de lecture : 1048576

Nombre total d'enregistrements logiques ignorés : 0
Nombre total d'enregistrements logiques lus : 41
Nombre total d'enregistrements logiques rejetés : 4
Nombre total d'enregistrements logiques mis au rebut : 0

Le début de l'exécution a été effectué sur Mer. Févr. 20 17:51:18 2008
La fin de l'exécution a été effectuée sur Mer. Févr. 20 17:51:24 2008

Temps écoulé (ELAPSED) : 00:00:05.61
Temps processeur (CPU) : 00:00:00.17
Ajouter un commentaire
Réponse
+0
moins plus
Ok, peux-tu nous copier-coller le contenu du fichier .bad généré ?
Ajouter un commentaire
Réponse
+0
moins plus
voici mon ficher bad.txt:

seq_t_reservations.nextval;13;08/11/2005;NULL;NULL;46
seq_t_reservations.nextval;2;13/10/2005;NULL;NULL;43
seq_t_reservations.nextval;9;11/11/2005;NULL;NULL;46
seq_t_reservations.nextval;5;01/11/2005;NULL;NULL;19
Ajouter un commentaire
Réponse
+0
moins plus
Bonjour, à prioris, si tu as créé ta table sans dire que la colonne était non-null (NOT NULL), tu peux insérer des valeurs null dedans, (si c'est ce que tu souhaites), tu peux toujours essayé de rajouter la clause TRAILING NULLCOLS dans ton fichier de contrôle:
...
FIELDS TERMINATED BY ';'
TRAILING NULLCOLS
(RESERVATION_ID "db_seq.nextval" ,
EMPLOYEE_ID ,
...
Mais de mémoire, ca converti un champs VIDE en NULL, donc ça ne devrait pas t'arranger, je pense que c'est le to_number qui quand il prend NULL pour le convertir déclanche cette erreur... Si je trouve quelque chose, je repasse.

A plus
Ajouter un commentaire
Ce document intitulé « SQL Loader erreur avec .nextval » issu de CommentCaMarche (www.commentcamarche.net) est mis à disposition sous les termes de la licence Creative Commons. Vous pouvez copier, modifier des copies de cette page, dans les conditions fixées par la licence, tant que cette note apparaît clairement.
Dossier à la une
Passage au tout numérique : quel coût pour les particuliers ?