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

Dotnet Discussion :

Datetime SQL Server avec Proc Stock Parameterized


Sujet :

Dotnet

  1. #1
    Membre du Club
    Profil pro
    Inscrit en
    Septembre 2009
    Messages
    111
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2009
    Messages : 111
    Points : 52
    Points
    52
    Par défaut Datetime SQL Server avec Proc Stock Parameterized
    Bonjour,

    Je suis assez embêter avec un petit point.

    J'ai une proc stock avec des paramètres comme ceci :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    commandeInsert.Parameters.Add(new SqlParameter("@data8", data[8]);
    data[8] contient un string de la forme "27/08/2012"

    et ma proc stock a comme paramètre @data8 DATETIME,

    et pour finir la base de données SQL Server à bien une colonne en DATETIME.

    Actuellement lorsque j'insère comme cela il me dit que j'ai un problème de string => Datetime.

    Du coup j'ai voulu faire ceci :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    commandeInsert.Parameters.Add(new SqlParameter("@data8", Convert.ToDateTime(data[8])));
    //ou
    commandeInsert.Parameters.Add(new SqlParameter("@data8", DateTime.Parse(data[8])));
    La ça passe mais dans la base de données il y a aussi l'heure et ce n'est donc plus de la forme dd/MM/yyyy.

    Du coup j'ai essayé ceci :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    commandeInsert.Parameters.Add(new SqlParameter("@data8", DateTime.ParseExact(data[8], "dd/MM/yyyy", new CultureInfo("fr-fr"))));
    //ou
    commandeInsertOrUpdate.Parameters.Add(new SqlParameter("@data8", DateTime.ParseExact(data[8], "dd/MM/yyyy", 103)));
    mais je n'ai toujours pas le résultat escompté :/

    Je veux donc simplement pouvoir avec un datetime de la forme dd/MM/yyyy dans ma table mais bêtement je n'y arrive pas. C'est possible au moins ce que je veux faire ?

    Une idée?

    Merci pour l'aide !

  2. #2
    Expert éminent
    Avatar de Immobilis
    Homme Profil pro
    Développeur .NET
    Inscrit en
    Mars 2004
    Messages
    6 559
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Développeur .NET

    Informations forums :
    Inscription : Mars 2004
    Messages : 6 559
    Points : 9 506
    Points
    9 506
    Par défaut
    Salut
    Citation Envoyé par quake3 Voir le message
    Je veux donc simplement pouvoir avec un datetime de la forme dd/MM/yyyy dans ma table mais bêtement je n'y arrive pas. C'est possible au moins ce que je veux faire ?
    Non. Comme son nom l'indique tu auras toujours l'heure. Après se pose le problème du format pour préciser la valeur du jour et du mois. Il peut y avoir confusion. Ainsi, 01/02/2013 peut être interprété différemment.

    Si tu tiens vraiment à garder la date ainsi (je comprends pas trop pourquoi), tu devras utiliser une chaîne de 10 caractères.

    A+
    "Winter is coming" (ma nouvelle page d'accueil)

  3. #3
    Rédacteur/Modérateur
    Avatar de Skalp
    Homme Profil pro
    Développeur .NET
    Inscrit en
    Novembre 2006
    Messages
    1 694
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Ille et Vilaine (Bretagne)

    Informations professionnelles :
    Activité : Développeur .NET

    Informations forums :
    Inscription : Novembre 2006
    Messages : 1 694
    Points : 2 927
    Points
    2 927
    Par défaut
    Citation Envoyé par quake3 Voir le message
    la base de données SQL Server à bien une colonne en DATETIME.
    [...]
    La ça passe mais dans la base de données il y a aussi l'heure et ce n'est donc plus de la forme dd/MM/yyyy.
    [...]
    Je veux donc simplement pouvoir avec un datetime de la forme dd/MM/yyyy dans ma table mais bêtement je n'y arrive pas. C'est possible au moins ce que je veux faire ?
    La colonne est de type DATETIME, donc elle stocke forcément une heure.

    Tu devrais peut-être plutôt utiliser le format DATE qui ne gère pas l'heure : voir cet article MSDN

Discussions similaires

  1. Réponses: 1
    Dernier message: 01/06/2015, 11h05
  2. [Débutant] implémenter une procédure stockée SELECT en SQL SERVER avec Entity Framework
    Par Alexandre le Grand dans le forum Entity Framework
    Réponses: 5
    Dernier message: 09/01/2014, 16h04
  3. [Débutant] Datetime c# imcompatible avec Datetime SQL server
    Par DIDIF dans le forum ASP.NET
    Réponses: 3
    Dernier message: 06/08/2012, 13h03
  4. [SQL-SERVER 2005]Procédure stockée avec table temporaire
    Par mathieu44800 dans le forum MS SQL Server
    Réponses: 8
    Dernier message: 03/08/2007, 14h18
  5. Réponses: 3
    Dernier message: 18/11/2002, 16h36

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