Précédent   Forum des professionnels en informatique > Bases de données > Oracle > SQL
SQL Forum d'entraide sur le SQL pour Oracle
Partagez cette discussion sur d'autres réseaux sociaux : Viadeo Twitter Google Facebook Digg Delicious MySpace Yahoo
Réponse Proposer ce sujet en actualité
 
Outils de la discussion
Publicité
'
Vieux 27/02/2011, 11h56   #1
 
Inscription : février 2011
Messages : 4
Détails du profil
Informations forums :
Inscription : février 2011
Messages : 4
Points : -1
Points : -1
Par défaut erreur avec la fonction to_date

Bonjour,

Je suis en train de finir un projet Java / Oracle et je dois faire une insertion dans la base depuis mon programme.

Ma requête est la suivante :
Code :
INSERT INTO employe (numero,nom,prenom,mail,date_entree,code_fonction,code_service)VALUES ('abc123','aaaaa','bbbbb','aaaa@bbbb.com','TO_DATE('27-Feb-11','DD-MON-YY')','DBA','INFO');
Oracle me renvoie une erreur ORA-00917:
Citation:
missing comma que je ne comprend pas.
Quand je fais la requête suivante directement avec Oracle ça marche mais pas en Java (ça je pense que c'est parce que côté Java tout est considéré comme chaîne de caractères) :
Code :
INSERT INTO employe (numero,nom,prenom,mail,date_entree,code_fonction,code_service)VALUES ('abc123','aaaaa','bbbbb','aaaa@bbbb.com','27-Feb-11','DBA','INFO');
Merci de votre aide.
logredebarbak est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 27/02/2011, 20h44   #2
Membre actif
 
Inscription : février 2007
Messages : 167
Détails du profil
Informations forums :
Inscription : février 2007
Messages : 167
Points : 161
Points : 161
Code :
1
2
3
4
5
 
INSERT INTO employe (numero,nom,prenom,mail,date_entree,code_fonction,code_service)
VALUES ('abc123','aaaaa','bbbbb','aaaa@bbbb.com',
'TO_DATE('27-Feb-11','DD-MON-YY')',
'DBA','INFO');
Le to_date ne doit pas être entre quotes c'est une fonction et pas une chaîne de caractères.
Je pense que après 'TO_DATE' qui est une chaîne Oracle attend une virgule.
Vous devriez retirer ces quotes.

Code :
1
2
3
4
5
 
INSERT INTO employe (numero,nom,prenom,mail,date_entree,code_fonction,code_service)
VALUES ('abc123','aaaaa','bbbbb','aaaa@bbbb.com',
TO_DATE('27-Feb-11','DD-MON-YY'),
'DBA','INFO');
Pozzo
Pozzo est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 27/02/2011, 22h44   #3
 
Inscription : février 2011
Messages : 4
Détails du profil
Informations forums :
Inscription : février 2011
Messages : 4
Points : -1
Points : -1
Par défaut Je progresse ...

Merci de votre réponse,

Je progresse, car en retirant les quotes, ce n'est plus la fonction TO_DATE qui est en erreur.
Maintenant j'ai cette erreur :
ORA-01843 : ce n'est pas un mois valide
Alors que quand j'exécute la même requête directement dans Oracle ça marche !

Il y a un post à ce sujet sur developpez.net mais la solution était de changer des variables :
Code :
1
2
ALTER session SET nls_date_format = 'DD-MON-YY';
ALTER SESSION SET nls_language = 'FRENCH';
quand je l'ai fait, que ce soit en ENGLISH ou FRENCH, j'ai toujours cette même erreur 01843.
logredebarbak est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 28/02/2011, 13h44   #4
 
Inscription : février 2011
Messages : 4
Détails du profil
Informations forums :
Inscription : février 2011
Messages : 4
Points : -1
Points : -1
Par défaut Réponse à moi même

J'ai trouvé une alternative à ce problème de date :
J'utilise la variable CURRENT_DATE de Oracle.
logredebarbak est déconnecté   Envoyer un message privé Réponse avec citation 01
Vieux 28/02/2011, 17h17   #5
Expert Confirmé Sénior
 
Avatar de mnitu
 
Homme Marius Nitu
Ingénieur développement logiciels
Inscription : octobre 2007
Messages : 3 311
Détails du profil
Informations personnelles :
Nom : Homme Marius Nitu
Localisation : France, Marne (Champagne Ardenne)

Informations professionnelles :
Activité : Ingénieur développement logiciels
Secteur : High Tech - Éditeur de logiciels

Informations forums :
Inscription : octobre 2007
Messages : 3 311
Points : 5 808
Points : 5 808
Vous n'avez pas compris grand chose n'est pas vrai ?
Code :
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
 
Connected TO Oracle DATABASE 10g Enterprise Edition Release 10.2.0.4.0 
Connected AS mni
 
SQL> 
SQL> SELECT TO_DATE('27-Feb-11','DD-MON-YY')
  2  FROM Dual
  3  /
 
SELECT TO_DATE('27-Feb-11','DD-MON-YY')
FROM Dual
 
ORA-01843: ce n'est pas un mois valide
 
SQL> 
SQL> Select TO_DATE('27-Févr.-11','DD-MON-YY')
  2    From dual
  3  /
 
TO_DATE('27-FÉVR.-11','DD-MON-
------------------------------
27/02/2011
 
SQL>
Il est très probable que vous voulez dire sysdate et non pas current_date.
mnitu est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 28/02/2011, 17h43   #6
 
Inscription : février 2011
Messages : 4
Détails du profil
Informations forums :
Inscription : février 2011
Messages : 4
Points : -1
Points : -1
Effectivement je n'avais pas compris grand chose...
J'ai trouvé une solution de dépannage car j'avais un projet à finir urgemment.

Je comprend mieux avec vos explications, ce n'est pas qu'un problème de dates c'est aussi un problème de langue.

Par contre pour la solution que j'ai trouvé, je ne sais pas si c'est une bonne chose mais j'utilise bien CURRENT_DATE :
Code :
INSERT INTO employe VALUES ('truc','truc','truc','truc',CURRENT_DATE,'truc','truc')
logredebarbak est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 01/03/2011, 11h38   #7
Expert Confirmé Sénior
 
Avatar de mnitu
 
Homme Marius Nitu
Ingénieur développement logiciels
Inscription : octobre 2007
Messages : 3 311
Détails du profil
Informations personnelles :
Nom : Homme Marius Nitu
Localisation : France, Marne (Champagne Ardenne)

Informations professionnelles :
Activité : Ingénieur développement logiciels
Secteur : High Tech - Éditeur de logiciels

Informations forums :
Inscription : octobre 2007
Messages : 3 311
Points : 5 808
Points : 5 808
Sysdate et Current_Date
A vous de voir quelle est la plus appropriée.
mnitu est déconnecté   Envoyer un message privé Réponse avec citation 00
Réponse Proposer ce sujet en actualité
Outils de la discussion



Fuseau horaire GMT +2. Il est actuellement 17h18.


 
 
 
 
Partenaires

Hébergement Web