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

ASP.NET Discussion :

[C#] Problème de Date lors d'un Insert


Sujet :

ASP.NET

  1. #1
    Membre averti
    Profil pro
    Inscrit en
    Juillet 2004
    Messages
    40
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2004
    Messages : 40
    Par défaut [C#] Problème de Date lors d'un Insert
    Bonjour j'obtiens un erreur lorsque je tente de faire un Insert dans la base de données.

    Voici la requête SQL :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    requete = "INSERT INTO Ent_Copie (Date_Cop) " +
    	"VALUES ('" + Convert.ToDateTime DateTime.Today.ToShortDateString()) + "') " ;
    Un exemple de requête :"
    INSERT INTO Ent_Copie (Date_Cop) VALUES ('2005-08-19 00:00:00')

    Tant qu'à y être j'aimerais me débarrasser de l'heure à 0.

    Voici l'erreur que j'obtient :
    La conversion d'un type de données CHAR en type DATETIME a donné une valeur hors des limites des valeurs de date et d'heure. L'instruction a été arrêtée.
    Merci de votre aide

  2. #2
    Membre habitué
    Profil pro
    Inscrit en
    Mars 2003
    Messages
    13
    Détails du profil
    Informations personnelles :
    Localisation : Canada

    Informations forums :
    Inscription : Mars 2003
    Messages : 13
    Par défaut
    1ere chose : ton code me parait bizarre ; tu convertis une date en string
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    DateTime.Today.ToShortDateString()
    et ensuite tu la reconvertis en DataTime
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Convert.ToDateTime(DateTime.Today.ToShortDateString())
    à quoi çà sert ?

    essaye plutot çà :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
    string requete = "INSERT INTO Ent_Copie (Date_Cop) " + 
    "VALUES ('" + DateTime.Today.ToShortDateString() + "') " ;
    Si çà ne marche pas, voici une eventuelle cause (mais çà pourrait etre aute chose ...) :
    le serveur SQL est-il paramétré en anglais ? car si oui, il ne reconnait peut etre pas le format de la date yyyy/mm/jj mais il s'attend à avoir yyyy/jj/mm comme c'est l'usage aux US.
    Pour etre sur essaye de coder en dur l'insert comme çà :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    INSERT INTO Ent_Copie (Date_Cop) VALUES ('01-01-01')
    Si cet insert marche alors çà vient de là.

    Derniere chose : le 00:00:00 vient du faire que tu reconvertit en DateTime car ToShortDateString ne renvoit que jour/mois/annee.

  3. #3
    Membre averti
    Inscrit en
    Avril 2005
    Messages
    28
    Détails du profil
    Informations forums :
    Inscription : Avril 2005
    Messages : 28
    Par défaut
    Si j'étais toi je ferais la chose suivante :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    string requete = "INSERT INTO Ent_Copie (Date_Cop) VALUES (@dateCop)";
    SqlCommand query = new SqlCommand(requete, connexion);
    query.Parameters.Add("@dateCop", SqlDbType.DateTime);
    query.Parameters["@dateCop"].Value = DateTime.Today;
    query.ExecuteNonQuery();
    ...
    Comme ça, c'est lui qui s'occupe de mettre la date au format qui va bien.

  4. #4
    jab
    jab est déconnecté
    Rédacteur
    Avatar de jab
    Homme Profil pro
    SharePoint developpeur
    Inscrit en
    Février 2004
    Messages
    1 173
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 61
    Localisation : Belgique

    Informations professionnelles :
    Activité : SharePoint developpeur
    Secteur : Service public

    Informations forums :
    Inscription : Février 2004
    Messages : 1 173
    Par défaut
    Citation Envoyé par Procto
    Si j'étais toi je ferais la chose suivante :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    string requete = "INSERT INTO Ent_Copie (Date_Cop) VALUES (@dateCop)";
    SqlCommand query = new SqlCommand(requete, connexion);
    query.Parameters.Add("@dateCop", SqlDbType.DateTime);
    query.Parameters["@dateCop"].Value = DateTime.Today;
    query.ExecuteNonQuery();
    ...
    Comme ça, c'est lui qui s'occupe de mettre la date au format qui va bien.
    +1.
    C'est beaucoup plus propre et plus portable même si c'est plus long à coder.

  5. #5
    Membre averti
    Profil pro
    Inscrit en
    Juillet 2004
    Messages
    40
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2004
    Messages : 40
    Par défaut
    Et bien allons-y comme ça.

    Merci beaucoup !

  6. #6
    jab
    jab est déconnecté
    Rédacteur
    Avatar de jab
    Homme Profil pro
    SharePoint developpeur
    Inscrit en
    Février 2004
    Messages
    1 173
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 61
    Localisation : Belgique

    Informations professionnelles :
    Activité : SharePoint developpeur
    Secteur : Service public

    Informations forums :
    Inscription : Février 2004
    Messages : 1 173
    Par défaut
    Pense au tag

    Merci.

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

Discussions similaires

  1. Validation format date lors de l'insertion
    Par Han Han dans le forum Développement Web en Java
    Réponses: 3
    Dernier message: 13/07/2013, 11h10
  2. [AC-2010] Conversion d'une valeur date lors d'un insert
    Par Mut dans le forum Requêtes et SQL.
    Réponses: 11
    Dernier message: 12/06/2012, 10h44
  3. Problème données de type date lors de l'insertion
    Par NarbOni dans le forum Administration
    Réponses: 1
    Dernier message: 12/04/2011, 10h28
  4. Conversion d'une chaine en date lors d'une insertion
    Par fedexpress dans le forum Développement
    Réponses: 1
    Dernier message: 27/10/2009, 13h08
  5. PB date lors d'une insertion en Base.
    Par NATHW dans le forum Langage SQL
    Réponses: 4
    Dernier message: 09/09/2004, 17h53

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