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

MS SQL Server Discussion :

Exprimer en where sur datetime ne tenant compte que de date


Sujet :

MS SQL Server

  1. #1
    Membre expérimenté
    Profil pro
    Mangeur de gauffre
    Inscrit en
    Octobre 2007
    Messages
    4 413
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations professionnelles :
    Activité : Mangeur de gauffre

    Informations forums :
    Inscription : Octobre 2007
    Messages : 4 413
    Par défaut Exprimer en where sur datetime ne tenant compte que de date
    Bonjour

    Par quel cast, conversion, flooring ou que sais-je faut-il passer pour exprimer proprement un where sur un champ DateTime ou seule la date doit etre signifiante

    genre

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    where DateTime=2010/04/03
    Merci de votre aide

  2. #2
    Invité
    Invité(e)
    Par défaut
    on peut faire comme ça mais c'est loin d'être optimal car conversion en char :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    convert ( nvarchar, ma_date , 103 ) = '06/04/2010'
    Comme ceci, ça doit être plus optimale car on manipule des dates seulement :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    ma_date >= '06/04/2010' and ma_date < '07/04/2010'

  3. #3
    Membre expérimenté
    Profil pro
    Mangeur de gauffre
    Inscrit en
    Octobre 2007
    Messages
    4 413
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations professionnelles :
    Activité : Mangeur de gauffre

    Informations forums :
    Inscription : Octobre 2007
    Messages : 4 413
    Par défaut
    Merci Jerome_Mtl

    Je suis quand meme etonné qu'il n'y ait pas une maniere plus "intégréeé

  4. #4
    Expert confirmé
    Avatar de mikedavem
    Homme Profil pro
    Administrateur de base de données
    Inscrit en
    Août 2005
    Messages
    5 450
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 46
    Localisation : France, Ain (Rhône Alpes)

    Informations professionnelles :
    Activité : Administrateur de base de données
    Secteur : Distribution

    Informations forums :
    Inscription : Août 2005
    Messages : 5 450
    Par défaut
    Bonsoir,

    Vous utilisez quelle version de SQL Server ?

    ++

  5. #5
    Modérateur

    Homme Profil pro
    Administrateur de base de données
    Inscrit en
    Janvier 2005
    Messages
    5 826
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Administrateur de base de données
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Janvier 2005
    Messages : 5 826
    Par défaut
    Bonjour,

    Si la colonne de type datetime est indexée alors spécifier dans la requête une date sous la forme d'une chaine de caractères entraîne une conversion implicite qui empêche l'utilisation de l'index, et donc des performances pauvres.

    Dans votre cas vous allez donc être obligé de déclarer deux variables et de les affecter comme suit :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    DECLARE @dateDebut datetime
    	, @dateFin datetime
     
    SELECT	@dateDebut = CAST(CONVERT(CHAR(8), GETDATE(), 112) AS datetime)
    	, @dateFin = @dateDebut + 1
    Vous pouvez ensuite utiliser le prédicat BETWEEN :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    WHERE DateTime BETWEEN @dateDebut AND @dateFin
    Pour affecter @dateDebut, vous pouvez aussi utiliser :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    SELECT	@dateDebut = CAST(FLOOR(CAST(GETDATE() AS FLOAT)) AS datetime)
    	, @dateFin = @dateDebut + 1
    Dans les deux cas vous pouvez remplacer GETDATE() par une variable de type datetime.

    Enfin, si vous êtes sous SQL Server 2008, vous pouvez écrire :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    DECLARE @maDate date = '20100406'
    DECLARE @dateDebut datetime = @maDate
    DECLARE @dateFin datetime = @dateDebut + 1
    Et réutiliser par la suite le prédicat BETWEEN

    @++

  6. #6
    Membre expérimenté
    Profil pro
    Mangeur de gauffre
    Inscrit en
    Octobre 2007
    Messages
    4 413
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations professionnelles :
    Activité : Mangeur de gauffre

    Informations forums :
    Inscription : Octobre 2007
    Messages : 4 413
    Par défaut
    Citation Envoyé par mikedavem Voir le message
    Bonsoir,

    Vous utilisez quelle version de SQL Server ?

    ++
    La version 2005 ET 2008

  7. #7
    Membre expérimenté
    Profil pro
    Mangeur de gauffre
    Inscrit en
    Octobre 2007
    Messages
    4 413
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations professionnelles :
    Activité : Mangeur de gauffre

    Informations forums :
    Inscription : Octobre 2007
    Messages : 4 413
    Par défaut
    Merci Elsuket pour ta réponse tres complète

  8. #8
    Expert confirmé
    Avatar de mikedavem
    Homme Profil pro
    Administrateur de base de données
    Inscrit en
    Août 2005
    Messages
    5 450
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 46
    Localisation : France, Ain (Rhône Alpes)

    Informations professionnelles :
    Activité : Administrateur de base de données
    Secteur : Distribution

    Informations forums :
    Inscription : Août 2005
    Messages : 5 450
    Par défaut
    Si vous utilisez SQL Server 2008 vous pouvez bénéficier du transtypage du type datetime en date sans perdre la possiblité d'utiliser un éventuel index.

    Je vous laisse lire le billet que j'ai écrit à ce sujet.

    ++

  9. #9
    Membre expérimenté
    Profil pro
    Mangeur de gauffre
    Inscrit en
    Octobre 2007
    Messages
    4 413
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations professionnelles :
    Activité : Mangeur de gauffre

    Informations forums :
    Inscription : Octobre 2007
    Messages : 4 413
    Par défaut
    Merci Mikedavem

Discussions similaires

  1. Convertir timestamp et datetime en javascript en tenant compte du fuseau horaire
    Par encoremoi21258 dans le forum Général JavaScript
    Réponses: 4
    Dernier message: 15/06/2015, 21h44
  2. [XL-2003] addition en tenant compte de la date et du format personnalisé
    Par therese067117 dans le forum Macros et VBA Excel
    Réponses: 3
    Dernier message: 24/11/2012, 09h08
  3. Réponses: 9
    Dernier message: 17/02/2011, 17h14
  4. [Oracle] La lecture d'un champ datetime ne me renvoie que la date
    Par josediaz dans le forum PHP & Base de données
    Réponses: 3
    Dernier message: 18/07/2006, 17h13
  5. where sur la première colonne
    Par r-zo dans le forum Requêtes
    Réponses: 8
    Dernier message: 28/07/2003, 09h55

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