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

C# Discussion :

comparer date en sql


Sujet :

C#

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Inscrit en
    Janvier 2008
    Messages
    57
    Détails du profil
    Informations forums :
    Inscription : Janvier 2008
    Messages : 57
    Par défaut comparer date en sql
    salut,
    je suis entrein de préparer un web service de réservation dans un hotel.(avec Visual Studio 2005)
    j'ai une table T_PERIODE_HOTEL(#Num_HOT, #Num_PER, Dat_deb_PER_HOT, Dat_fin_PER_HOT)

    Dat_deb_PER_HOT et Dat_fin_PER_HOT sont de type datetime (de SQL SERVER 2005).

    => je veux séléctionner la date de fin d'une periode de l'hotel numéro 1qui a comme date de debut de la periode = "date_deb_per "
    voici mon code:

    public String dispo_hotel(DateTime date_deb_per)
    {
    ...... // connection

    string strQuery = "select Dat_fin_PER_HOT from T_PERIODE_HOTEL where sa_Num_HOT = 1 and Dat_deb_PER_HOT <= '" + date_deb_per + "'";
    connexion.ConnectionString = connectString;
    System.Data.SqlClient.SqlCommand oCommand = new System.Data.SqlClient.SqlCommand(strQuery, connexion);
    connexion.Open();
    System.Data.SqlClient.SqlDataReader oReader = oCommand.ExecuteReader();
    string j = "";
    while (oReader.Read())
    {
    if (oReader[0].ToString() != null)

    j = (String)oReader[0].ToString();
    }
    oReader.Close();
    connexion.Close();
    return j;
    }

    ce code m'affiche une erreur "System.ArgumentException: Impossible de convertir 15/07/2008 en System.DateTime." si date_deb_per= 15/07/2008
    et il m'affiche "System.ArgumentException: Impossible de convertir 15/07/2008 00:00:00 en System.DateTime.
    " si date_deb_per= 15/07/2008 00:00:00
    => ces erreurs sont affiché au niveau du web service
    (aprés dans ma web form date_deb_per sera de type string que je la convertie en datetime pour faire la comparaison)
    est ce qu'il ya quelqu'un qui peut m'aider

  2. #2
    Rédacteur
    Avatar de SaumonAgile
    Homme Profil pro
    Team leader
    Inscrit en
    Avril 2007
    Messages
    4 028
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Moselle (Lorraine)

    Informations professionnelles :
    Activité : Team leader
    Secteur : Conseil

    Informations forums :
    Inscription : Avril 2007
    Messages : 4 028
    Besoin d'un MessageBox amélioré ? InformationBox pour .NET 1.1, 2.0, 3.0, 3.5, 4.0 sous license Apache 2.0.

    Bonnes pratiques pour les accès aux données
    Débogage efficace en .NET
    LINQ to Objects : l'envers du décor

    Mon profil LinkedIn - MCT - MCPD WinForms - MCTS Applications Distribuées - MCTS WCF - MCTS WCF 4.0 - MCTS SQL Server 2008, Database Development - Mon blog - Twitter

  3. #3
    Membre Expert
    Homme Profil pro
    Inscrit en
    Juillet 2007
    Messages
    1 277
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Réunion

    Informations forums :
    Inscription : Juillet 2007
    Messages : 1 277
    Par défaut
    Bonjour,

    Ta fonction prend un DateTime mais tu sembles vouloir y passer une string. Pour plein de raisons évidentes (comme la culture), il n'y a pas de conversion automatique d'une string qui contiendrait une date en DateTime. Pour cela, il faut que tu regardes la documentation du côté de l'objet DateTime et les méthodes statiques DateTime.Parse(...).

    PS : la méthode de SaumonAgile est plus robuste

  4. #4
    Futur Membre du Club
    Inscrit en
    Mars 2008
    Messages
    5
    Détails du profil
    Informations forums :
    Inscription : Mars 2008
    Messages : 5
    Par défaut DateTime
    essaies ça
    SqlCommand oCommand = new SqlCommand();
    oCommand.CommandText = strQuery;
    oCommand.Connection = connexion;
    oCommand.Parameters.Add("@date_deb_per", DbType.DateTime);
    oCommand.Parameters["@date_deb_per"].Value = date_deb_per;

  5. #5
    Futur Membre du Club
    Inscrit en
    Mars 2008
    Messages
    5
    Détails du profil
    Informations forums :
    Inscription : Mars 2008
    Messages : 5
    Par défaut DateTime
    Ta requête ressemblera à ça bien sur
    string strQuery = "select Dat_fin_PER_HOT from T_PERIODE_HOTEL where sa_Num_HOT = 1 and Dat_deb_PER_HOT <= @date_deb_per";

Discussions similaires

  1. Comparer date SQL/Date du jour
    Par mr-nameless dans le forum Débuter
    Réponses: 0
    Dernier message: 30/10/2009, 16h31
  2. Comparer date/heure dans une requête SQL
    Par ach152 dans le forum Débuter
    Réponses: 9
    Dernier message: 13/07/2008, 14h24
  3. Comment comparer deux date en SQL Server avec VB.NET
    Par Pedro Varela dans le forum MS SQL Server
    Réponses: 4
    Dernier message: 11/09/2006, 15h26
  4. Help!! Probleme avec les dates sur SQL SERVER
    Par Nadaa dans le forum MS SQL Server
    Réponses: 16
    Dernier message: 03/08/2006, 16h55
  5. comparer deux dates sur sql
    Par Tenro dans le forum Requêtes et SQL.
    Réponses: 3
    Dernier message: 07/05/2006, 17h19

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