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

Développement SQL Server Discussion :

regrouper datetime par heure


Sujet :

Développement SQL Server

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Inscrit en
    Janvier 2009
    Messages
    41
    Détails du profil
    Informations forums :
    Inscription : Janvier 2009
    Messages : 41
    Par défaut regrouper datetime par heure
    Mon but est de sortir un tableau qui me sorte le nb de commandes par heure or j'ai la liste des commandes par datetime de la commande.
    Quelqu'un a t il la solution pour ma where clause?
    Je suis sous sql server 2008.

    select count(commande)
    from table_commande
    where ?

    Merci
    Pastoi

  2. #2
    Membre Expert

    Homme Profil pro
    Chargé de Développement et d'Analyse de données
    Inscrit en
    Mars 2010
    Messages
    1 278
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Nord (Nord Pas de Calais)

    Informations professionnelles :
    Activité : Chargé de Développement et d'Analyse de données
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Mars 2010
    Messages : 1 278
    Par défaut
    Une idée, tu peux créer une table INTERVAL

    INTERVAL HEURE_MIN HEURE_MAX
    ---------- ---------- ------------

    1 ------------ 1 ------------ 2

    2 ------------ 2 ------------ 3
    .. .. ...

    23 ------------ 23 ------------ 24
    et faire une jointure entre cette table et la table commande
    Etienne ZINZINDOHOUE
    Billets-Articles

  3. #3
    Modérateur

    Profil pro
    dba
    Inscrit en
    Janvier 2010
    Messages
    5 643
    Détails du profil
    Informations personnelles :
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : dba

    Informations forums :
    Inscription : Janvier 2010
    Messages : 5 643
    Par défaut
    Bonjour,

    Poste ta requete, ca sera plus simple pour te repondre,

    Si j'ai bien compris, tu veux regrouper sur la l'heure, sans prendre en compte le jour, ni les minutes,...
    donc en gros savoir le nombre de commandes passées entre minuit et une heure, entre une heure et deux heures,...

    dans ce cas :
    Code sql : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
     
    SELECT 
      DATEPART(HOUR, MaDate) AS Heure
      , COUNT(*) AS NbCommandes
    FROM 
      MaTable
    GROUP BY DATEPART(HOUR, MaDate)

  4. #4
    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
    Notez qu'un GROUP BY sur une fonction est contre-performant, à moins que la fonction soit une colonne calculée indexée de la table, ou que vous utilisiez une vue indexée ...

    @++

  5. #5
    Rédacteur

    Avatar de SQLpro
    Homme Profil pro
    Expert bases de données / SQL / MS SQL Server / Postgresql
    Inscrit en
    Mai 2002
    Messages
    22 010
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Var (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Expert bases de données / SQL / MS SQL Server / Postgresql
    Secteur : Conseil

    Informations forums :
    Inscription : Mai 2002
    Messages : 22 010
    Billets dans le blog
    6
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    SELECT CONVERT(CHAR(10), MaDate, 121) AS D, 
           DATEPART(HOUR, MaDate) AS H,
           COUNT(*) AS NOMBRE
    FROM   MaTable
    GROUP BY CONVERT(CHAR(10), MaDate, 121), 
             DATEPART(HOUR, MaDate)
    A +
    Frédéric Brouard - SQLpro - ARCHITECTE DE DONNÉES - expert SGBDR et langage SQL
    Le site sur les SGBD relationnels et le langage SQL: http://sqlpro.developpez.com/
    Blog SQL, SQL Server, SGBDR : http://blog.developpez.com/sqlpro
    Expert Microsoft SQL Server - M.V.P. (Most valuable Professional) MS Corp.
    Entreprise SQL SPOT : modélisation, conseils, audit, optimisation, formation...
    * * * * * Expertise SQL Server : http://mssqlserver.fr/ * * * * *

  6. #6
    Membre à l'essai
    Homme Profil pro
    Inscrit en
    Avril 2011
    Messages
    5
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Avril 2011
    Messages : 5
    Par défaut
    Bonjour à tous,

    Je me permets de relancer le thread avec la question suivante :
    Et si on veut regrouper par 1/2 heure, par 1/4 d'heure, etc... ???!

    ca m'intéresserait fortement!!

    Merci d'avance pour toute idées!

    DF4ze

    --------
    Modif :
    Je viens de trouver ca ...

    mais ne serait-il pas possible d'éviter la table temporaire?
    --> J'ai qu'un acces en lecture ... je ne peux pas créer de table supplémentaire...

Discussions similaires

  1. Requête DateTime sur une semaine groupée par jour et par heure
    Par cerealkiller dans le forum Langage SQL
    Réponses: 1
    Dernier message: 10/08/2011, 15h54
  2. Champs DateTime trier par heure
    Par lucazzo dans le forum MS SQL Server
    Réponses: 5
    Dernier message: 03/06/2010, 17h20
  3. Calcul d'une quantité par heure
    Par orzra dans le forum C#
    Réponses: 6
    Dernier message: 12/06/2007, 13h28
  4. Tri TStringList par heure
    Par rxseac dans le forum Delphi
    Réponses: 3
    Dernier message: 16/03/2007, 11h41
  5. graphique heure par heure
    Par loric92 dans le forum Access
    Réponses: 1
    Dernier message: 09/02/2007, 17h26

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