Précédent   Forum des professionnels en informatique > Logiciels > Microsoft Office > Access > Requêtes et SQL.
Requêtes et SQL. Tout ce qui concerne vos questions sur les requêtes et le SQL sous Access se trouve ici.
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 24/12/2010, 15h54   #1
Candidat au titre de Membre du Club
 
Inscription : novembre 2008
Messages : 132
Détails du profil
Informations forums :
Inscription : novembre 2008
Messages : 132
Points : 12
Points : 12
Par défaut La date n'est pas enregistrée comme il faut.

Bonjour

J'ai une table "Client" avec ses champs suivants :Client(matricule,nom,prenom,date_naissance) dans une base de données MS Access 2003.

J'ai exécuté avec succès la requete d'insertion suivant:
Code sql :
INSERT INTO Client VALUES(1,'nom1','prenom1',#01/02/2010#)

le souci est j'ai trouvé que la date enregistrée est : 02/01/2010 à la place de 01/02/2010,sachant que le format de ce champ est :"Date, abrégé".

comment faire?

merci
barchoui est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 24/12/2010, 16h17   #2
Rédacteur
 
Avatar de LedZeppII
 
Homme
Maintenance données produits
Inscription : décembre 2005
Messages : 3 939
Détails du profil
Informations personnelles :
Sexe : Homme
Localisation : France, Yvelines (Île de France)

Informations professionnelles :
Activité : Maintenance données produits
Secteur : Distribution

Informations forums :
Inscription : décembre 2005
Messages : 3 939
Points : 6 278
Points : 6 278
Bonjour,

Dans SQL et dans VBA les dates sont au format américain mois/jours/année.
Il faut donc respecter cette convention.

Pour le 1er février 2010, le SQL est :
Code :
insert into Client values(1,'nom1','prenom1',#02/01/2010#)
A+
LedZeppII est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 24/12/2010, 16h56   #3
Candidat au titre de Membre du Club
 
Inscription : novembre 2008
Messages : 132
Détails du profil
Informations forums :
Inscription : novembre 2008
Messages : 132
Points : 12
Points : 12
et qui ce je dois faire,parce que j'utilise un contrôle vb.net qui permet de sélection d'une date en format français.
barchoui est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 24/12/2010, 17h53   #4
Rédacteur
 
Avatar de LedZeppII
 
Homme
Maintenance données produits
Inscription : décembre 2005
Messages : 3 939
Détails du profil
Informations personnelles :
Sexe : Homme
Localisation : France, Yvelines (Île de France)

Informations professionnelles :
Activité : Maintenance données produits
Secteur : Distribution

Informations forums :
Inscription : décembre 2005
Messages : 3 939
Points : 6 278
Points : 6 278
Il faut que tu convertisse la date provenant de ton contrôle en texte au format mm/dd/yyyy.

Je ne connais pas très bien vb.net mais ça doit être la méthode ToString

A+
LedZeppII est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 25/12/2010, 16h55   #5
Candidat au titre de Membre du Club
 
Inscription : novembre 2008
Messages : 132
Détails du profil
Informations forums :
Inscription : novembre 2008
Messages : 132
Points : 12
Points : 12
ok

j'ai aissayé de reconstruire la requête précédente avec une manière,et alors j'ai mis '01/02/2010' à la place de #01/02/2010# et ca marche,mais je ne suis pas sûr si cette requête est valise ou pas,qui ce que vous pensez?
barchoui est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 25/12/2010, 19h31   #6
Rédacteur
 
Avatar de LedZeppII
 
Homme
Maintenance données produits
Inscription : décembre 2005
Messages : 3 939
Détails du profil
Informations personnelles :
Sexe : Homme
Localisation : France, Yvelines (Île de France)

Informations professionnelles :
Activité : Maintenance données produits
Secteur : Distribution

Informations forums :
Inscription : décembre 2005
Messages : 3 939
Points : 6 278
Points : 6 278
Bonsoir,

je me suis trompé hier en écrivant ma réponse.
Le format est mm/dd/yyyy.
Le caractère # à gauche et à droite de la date littérale indique à Sql que c'est une date.

En mettant '01/02/2010' dans le Sql, tu assignes une valeur de type texte dans un champ de type Date/Time.
Le moteur de base de données va tenter une conversion en s'appuyant sur les paramètres régionaux de Windows.
Ça marchera uniquement si dans les paramètres régionnaux la date est au format jour/mois/année.

En Vba on écrirait
Code :
1
2
strSql = "insert into Client values(1,'nom1','prenom1',"
strSql = strSql & "#" & Format(MonCtl.Value, "mm/dd/yyyy") & "#)"
En .net le format est "MM/dd/yyyy" car mm=minutes (voir ici).

A+
LedZeppII est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 25/12/2010, 20h29   #7
Candidat au titre de Membre du Club
 
Inscription : novembre 2008
Messages : 132
Détails du profil
Informations forums :
Inscription : novembre 2008
Messages : 132
Points : 12
Points : 12
tout à fait,tu as raison,j'ai essayé de tester avec l'instruction vb.net suivante:
Code :
 "#" & Format(Me.DTPDate.Value, "MM/dd/yyyy") & "#"
et ca marche très bien,meci beaucoup.
barchoui est déconnecté   Envoyer un message privé Réponse avec citation 00
Réponse Proposer ce sujet en actualité Cette discussion est résolue.
Outils de la discussion



Fuseau horaire GMT +2. Il est actuellement 11h16.


 
 
 
 
Partenaires

Hébergement Web