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

JDBC Java Discussion :

Comparaison de DATETIME


Sujet :

JDBC Java

  1. #1
    Membre à l'essai
    Inscrit en
    Septembre 2009
    Messages
    5
    Détails du profil
    Informations forums :
    Inscription : Septembre 2009
    Messages : 5
    Par défaut Comparaison de DATETIME
    Bonjour,

    Je cherche à envoyer des requêtes qui doivent vérifier si la date demandée est comprise entre une date de début et une date de fin.

    Je travaille avec SQLServer 2005 pour sgd et donc des dates au format DATETIME.

    Voici le genre de requête :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    SELECT COUNT(*)
    FROM table
    WHERE '2009-10-26' BETWEEN debut AND fin;
    debut et fin sont des champs de ma table.

    Lorsque j'envoie ces requêtes à partir de mon sgbd, aucun souci. Par contre, en envoyant strictement la même requête à partir de jdbc dans mon programme, je rencontre l'erreur suivante :

    com.microsoft.sqlserver.jdbc.SQLServerException: La conversion d'un type de données CHAR en type DATETIME a donné une valeur hors limite de date et d'heure.
    J'ai essayé de faire des casts dans tous les sens, de rajouter l'heure, de faire une comparaison au lieu d'un between, mais rien n'y fait. La requête fonctionne sur le sgbd mais pas avec jdbc

    Si quelqu'un a une petite idée,

    Merci d'avance

  2. #2
    Membre à l'essai
    Inscrit en
    Septembre 2009
    Messages
    5
    Détails du profil
    Informations forums :
    Inscription : Septembre 2009
    Messages : 5
    Par défaut
    Problème résolu,

    Le souci venait (je crois) du fait que, si l'on n'indique pas l'heure pour la date entre quotes, elle est par défaut à 00:00:00.000.

    Du coup, elle est était inférieure à ma date début qui elle est à une heure de la journée.

    J'ai donc fait deux comparaisons :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    '2009-10-26 23:59:59.999' >= debut
    AND '2009-10-26' <= fin
    Désolé pour l'ouverture de topic inutile

  3. #3
    Modérateur
    Avatar de Alkhan
    Homme Profil pro
    ingénieur full stack
    Inscrit en
    Octobre 2006
    Messages
    1 232
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : ingénieur full stack

    Informations forums :
    Inscription : Octobre 2006
    Messages : 1 232
    Par défaut
    bonjour,

    Le format des dates peux varier d'un base a l'autre. Afin de te simplifier le traitement je te conseil d'utiliser les "preparedStatement" car c'est le driver qui se charge du formatage de données envoyées.
    Il n'y a pas de problème, il n'y a que des solutions.
    Cependant, comme le disaient les shadoks, s'il n'y a pas de solution, c'est qu'il n'y a pas de problème.
    Si toutefois le problème persiste, la seule solution restante est de changer le périphérique qui se trouve entre la chaise et l'écran

    Mes Articles : Mon premier article est sur le language D
    N'oubliez pas de consulter les FAQ Java et les cours et tutoriels Java

  4. #4
    Modérateur
    Avatar de OButterlin
    Homme Profil pro
    Inscrit en
    Novembre 2006
    Messages
    7 313
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Novembre 2006
    Messages : 7 313
    Billets dans le blog
    1
    Par défaut
    Le problème de la comparaison vient du fait que tu ne veux tenir compte que de la partie date, pas date+heure.
    Tu peux faire de 2 façons :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    SELECT COUNT(*)
    FROM table
    WHERE champDateTime BETWEEN '2009-10-26 00:00:00' AND '2009-10-26 23:59:59'
    ou
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    SELECT COUNT(*)
    FROM table
    WHERE DATE(champDate)Time BETWEEN '2009-10-26' AND '2009-10-26'
    N'oubliez pas de consulter les FAQ Java et les cours et tutoriels Java

  5. #5
    Membre à l'essai
    Inscrit en
    Septembre 2009
    Messages
    5
    Détails du profil
    Informations forums :
    Inscription : Septembre 2009
    Messages : 5
    Par défaut
    Le format des dates peux varier d'un base a l'autre. Afin de te simplifier le traitement je te conseil d'utiliser les "preparedStatement" car c'est le driver qui se charge du formatage de données envoyées.
    Yep, j'utilise déjà les PreparedStatement, je ne l'ai juste pas indiqué, merci

    Le problème de la comparaison vient du fait que tu ne veux tenir compte que de la partie date, pas date+heure.
    Ouep, le truc avec ce que tu m'a donné c'est qu'ici, le '2009-10-26' est mon paramètre justement. Je dois vérifier que cette date est comprise entre debut et fin, qui eux sont des champs de ma table, et qui peuvent être différents jours, c'est pour ça que j'ai fait deux comparaisons.

    Merci pour vos réponses.

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

Discussions similaires

  1. Probleme de comparaison de datetime
    Par casawi dans le forum Développement
    Réponses: 11
    Dernier message: 23/08/2010, 19h18
  2. comparaison de deux datetime identique donne <
    Par olibara dans le forum C#
    Réponses: 3
    Dernier message: 22/04/2008, 15h52
  3. c# comparaison de deux DateTime
    Par Destiny dans le forum Windows Forms
    Réponses: 6
    Dernier message: 13/04/2007, 20h36
  4. [VBA-E] Comparaison date / datetime
    Par dahu29 dans le forum Macros et VBA Excel
    Réponses: 9
    Dernier message: 15/03/2006, 14h12
  5. [SYBASE] Comparaison de deux datetime
    Par paf15 dans le forum Sybase
    Réponses: 1
    Dernier message: 17/04/2005, 17h51

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