IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

VB.NET Discussion :

Problème de dates (jour et mois inversés)


Sujet :

VB.NET

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Profil pro
    Inscrit en
    Décembre 2008
    Messages
    16
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2008
    Messages : 16
    Par défaut Problème de dates (jour et mois inversés)
    Hé oui, un autre problème de dates!

    Dans ma BD de SQL Server, j'ai une table avec un champ de type DateTime.
    J'ai une application VB.Net qui ajoute des dates (en utilisant Date.Now) dans cette table.

    J'ai fait des tests en utlisant des msgbox après chaque ajout et lecture.
    Prenons la date d'aujourd'hui (6 août 2009); après un ajout, le msgbox affiche bel et bien les bonnes infos (jour: 6, mois: 8, année: 2009).

    Mais quand j'utilise un DataReader pour lire, ça m'affiche l'inverse pour le jour et mois! (jour: 8, mois: 6, année: 2009)

    Je suspecte alors que c'est le format de date dans SQL Server (J'utilise une version anglaise) qui est de JJ/MM/YYYY.

    Y-a-t-il une façon de changer le format par défaut?

  2. #2
    Expert éminent Avatar de Pol63
    Homme Profil pro
    .NET / SQL SERVER
    Inscrit en
    Avril 2007
    Messages
    14 198
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : France, Puy de Dôme (Auvergne)

    Informations professionnelles :
    Activité : .NET / SQL SERVER

    Informations forums :
    Inscription : Avril 2007
    Messages : 14 198
    Par défaut
    dans sql server, il faut que le login utilisé soit réglé sur francais (propriété sur le login, dans sécurité, dans le server directement, dans management studio)


    de plus il faut enregistrer les données dans la base avec des dbparameters plutot qu'une concaténation

    cmd.commandtext = "insert into table (chdate) values ('" & datatimepicker1.value & ')"
    => pas bien

    cmd.commandtext = "insert into table (chdate) values (@mavaleurdate)"
    cmd.parameters.Add("@mavaleurdate",datetime).value = datatimepicker1.value
    => bien
    Cours complets, tutos et autres FAQ ici : C# - VB.NET

  3. #3
    Membre averti
    Profil pro
    Inscrit en
    Décembre 2008
    Messages
    16
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2008
    Messages : 16
    Par défaut
    Salut!

    J'ai effectivement utilisé des concaténations pour mes insertions.

    J'ai modifié mon code pour utiliser les Parameters, mais malheureusement aucune donnée ne s'ajoute à la BD.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
     
    dim dateDebut as Date
     
    dateDebut = New Date(DatePicker.Value.Year, DatePicker.Value.Month, DatePicker.Value.Day)
     
    sqlInsert = "INSERT INTO Locations(DateDebut) VALUES (@DateDebut)"
     
    conn.Open()
     
    cmd = New SqlCommand(sqlInsert, conn)
    cmd.Parameters.Add("@DateDebut", SqlDbType.DateTime).Value = dateDebut
    dadapter.InsertCommand = cmd
    dadapter.Update(dset, "Locations")
     
    conn.Close()

  4. #4
    Expert éminent Avatar de Pol63
    Homme Profil pro
    .NET / SQL SERVER
    Inscrit en
    Avril 2007
    Messages
    14 198
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : France, Puy de Dôme (Auvergne)

    Informations professionnelles :
    Activité : .NET / SQL SERVER

    Informations forums :
    Inscription : Avril 2007
    Messages : 14 198
    Par défaut
    en meme temps tu retires ces 2 lignes de dataadapter et dataset de me***
    dadapter.InsertCommand = cmd
    dadapter.Update(dset, "Locations")

    et tu fais cmd.executenonquery
    Cours complets, tutos et autres FAQ ici : C# - VB.NET

  5. #5
    Membre averti
    Profil pro
    Inscrit en
    Décembre 2008
    Messages
    16
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2008
    Messages : 16
    Par défaut
    Wow, j'avais bien .ExecuteNonQuery() au début, mais je l'avais enlever pour InsertCommand et Update().

    Le msgbox affiche les bonnes infos maintenant...

    Merci sperot51!

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. [2.x] Form type date jours et mois non obligatoire
    Par jfsenechal dans le forum Symfony
    Réponses: 15
    Dernier message: 04/06/2014, 10h54
  2. [HighCharts] Affichage de ma date (jour et mois) dans la tooltip ?
    Par [ZiP] dans le forum Bibliothèques & Frameworks
    Réponses: 2
    Dernier message: 18/12/2013, 13h35
  3. Format date jour du mois en lettres
    Par Mykhell dans le forum SQL
    Réponses: 8
    Dernier message: 08/04/2009, 12h29
  4. Problème format date - SimpleDateFormat inversion mois/jour
    Par juanqui dans le forum Servlets/JSP
    Réponses: 8
    Dernier message: 07/02/2007, 14h37
  5. [Dates] Problème de date : jours ouvrés notamment
    Par rob2-9 dans le forum Langage
    Réponses: 2
    Dernier message: 31/01/2006, 13h46

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo