SQL Loader erreur avec .nextval
Résolu
Hellreaper
-
asevere Messages postés 13095 Date d'inscription Statut Webmaster Dernière intervention -
asevere Messages postés 13095 Date d'inscription Statut Webmaster Dernière intervention -
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,
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,
A voir également:
- SQL Loader erreur avec .nextval
- Windows loader - Télécharger - Gestion de fichiers
- Erreur 0x80070643 - Accueil - Windows
- J'aime par erreur facebook notification - Forum Facebook
- Code erreur f3500-31 ✓ - Forum Bbox Bouygues
- Java code erreur 1603 ✓ - Forum Windows
10 réponses
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... :)
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:
(Le programme appelant peut être récuperé entre autre par la requête suivante:
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:
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
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_sqlloaderQuatriè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
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
.....
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
.....
Vous n’avez pas trouvé la réponse que vous recherchez ?
Posez votre question
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
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
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
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
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
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
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:
A plus
... 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
Bon TP
pour tant j'ai bien mis :
sqlldr control=c:\dml_t_abo.ctl log=c:\log1.txt bad=c:\bad.txt
Enfin bref d'apres mon ficher log l'erreur viendrais du WHEN:
Fichier de contrôle : c:\dml_t_res.ctl
Fichier de données : C:\dmlres.csv
Fichier BAD : bad.txt
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é quand PRIX != 0X4e554c4c(caractère 'NULL')
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
Table DMLRES, chargé quand PRIX = 0X4e554c4c(caractère 'NULL')
Option d'insertion en vigueur pour cette table : TRUNCATE
Nom de colonne Position Long. Séparat. Encadrem. Type de données
------------------------------ ---------- ----- ---- ---- ---------------------
RESERVATION_ID NEXT * ; 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 13 : Rejeté - échec de toutes les clauses WHEN.
Enregistrement 18 : Rejeté - échec de toutes les clauses WHEN.
Enregistrement 23 : Rejeté - échec de toutes les clauses WHEN.
Enregistrement 31 : Rejeté - échec de toutes les clauses WHEN.
Table DMLRES :
Chargement réussi de 37 Lignes.
0 Lignes chargement impossible dû à des erreurs de données.
4 Lignes chargement impossible car échec de toutes les clauses WHEN.
0 Lignes chargement impossible car tous les champs étaient non renseignés.
Table DMLRES :
Chargement réussi de 0 Lignes.
0 Lignes chargement impossible dû à des erreurs de données.
41 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 : 198144 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 : 0
Nombre total d'enregistrements logiques mis au rebut : 4
Le début de l'exécution a été effectué sur Mar. Févr. 26 00:44:32 2008
La fin de l'exécution a été effectuée sur Mar. Févr. 26 00:44:40 2008
Temps écoulé (ELAPSED) : 00:00:09.22
Temps processeur (CPU) : 00:00:00.07
Table DMLRES, chargé quand PRIX != 0X4e554c4c(caractère 'NULL')
A tout hasard, essayes avec des doubles quotes autour des NULLl dans les clause WHEN:
Peux-tu me montrer les lignes 13, 18, 23, 31 de ton fichier de données ?