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 :

Grouper en fonction du minimum par date


Sujet :

Développement SQL Server

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Homme Profil pro
    Développeur décisionnel
    Inscrit en
    Avril 2018
    Messages
    12
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 28
    Localisation : France, Ain (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur décisionnel
    Secteur : Biens de consommation

    Informations forums :
    Inscription : Avril 2018
    Messages : 12
    Par défaut Grouper en fonction du minimum par date
    Bonjour à tous,

    Nom : type_itv.JPG
Affichages : 239
Taille : 45,5 Ko

    Je souhaiterai récupérer seulement l'heure minimum pour chaque date, comme sur la photo ci-dessus mais je ne sais pas comment m'y prendre.

    Si vous avez besoin de plus d'informations sur les données n'hésitez pas.

  2. #2
    Modérateur
    Avatar de al1_24
    Homme Profil pro
    Retraité
    Inscrit en
    Mai 2002
    Messages
    9 136
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 64
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Retraité
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Mai 2002
    Messages : 9 136
    Par défaut
    S'il s'agit juste de "récupérer seulement l'heure minimum pour chaque date", la requête suivante devrait être suffisante... mais je suppose qu'il faut plus que ça
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    SELECT  dt_real
        ,   MIN(hr_depart)
    FROM    matable
    GROUP BY dt_real
    Modérateur Langage SQL
    Règles du forum Langage SQL à lire par tous, N'hésitez pas à consulter les cours SQL
    N'oubliez pas le bouton et pensez aux balises
    [code]
    Si une réponse vous a aidé à résoudre votre problème, n'oubliez pas de voter pour elle en cliquant sur
    Aide-toi et le forum t'aidera : Un problème exposé sans mentionner les tentatives de résolution infructueuses peut laisser supposer que le posteur attend qu'on fasse son travail à sa place... et ne donne pas envie d'y répondre.

  3. #3
    Membre averti
    Homme Profil pro
    Développeur décisionnel
    Inscrit en
    Avril 2018
    Messages
    12
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 28
    Localisation : France, Ain (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur décisionnel
    Secteur : Biens de consommation

    Informations forums :
    Inscription : Avril 2018
    Messages : 12
    Par défaut
    Bonjour al1_24 et merci pour ta réponse.

    En effet c'est un peu plus complexe que ça. Il faut que je récupère toute la ligne et même avec la fonction min je me retrouve avec des dates en doublons...
    La colonne hr_depart est en varchar, ça vient peut-être de là, mais j'ai testé min(cast(hr_depart as datetime)) sans succès

  4. #4
    Modérateur
    Avatar de al1_24
    Homme Profil pro
    Retraité
    Inscrit en
    Mai 2002
    Messages
    9 136
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 64
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Retraité
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Mai 2002
    Messages : 9 136
    Par défaut
    Si tu veux récupérer toute la ligne correspondant au critère spécifié, la requête suivante répondra à ton besoin.
    Ce n'est que l'une des manières de faire, il y en a d'autres.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    SELECT  *
    FROM    matable AS  tbl
    WHERE   EXISTS
            (   SELECT  NULL
                FROM    matable AS  sel
                WHERE   tbl.dt_real = sel.dt_real
                HAVING  tbl.hr_depart = MIN(sel.hr_depart)
            )
    Si avec cela tu as encore des doublons sur la date, ce sont tes données qu'il va falloir vérifier :
    • Quel est le type de la colonne dt_real (idéalement DATE) ?
    • Si la colonne est de type CHAR ou VARCHAR, y a-t-il des caractères parasites (séparateurs différents, espace à la fin de la chaine, O à la place du 0) ?
    • Si la colonne est de type DATETIME ou autre contenant des heures, l'heure est-elle bien à 00:00:00.000 ?
    Modérateur Langage SQL
    Règles du forum Langage SQL à lire par tous, N'hésitez pas à consulter les cours SQL
    N'oubliez pas le bouton et pensez aux balises
    [code]
    Si une réponse vous a aidé à résoudre votre problème, n'oubliez pas de voter pour elle en cliquant sur
    Aide-toi et le forum t'aidera : Un problème exposé sans mentionner les tentatives de résolution infructueuses peut laisser supposer que le posteur attend qu'on fasse son travail à sa place... et ne donne pas envie d'y répondre.

Discussions similaires

  1. Grouper des valeurs par date
    Par PIEPLU dans le forum Langage SQL
    Réponses: 6
    Dernier message: 12/06/2011, 23h38
  2. Grouper les données d'une listview par date
    Par mounaje dans le forum VB.NET
    Réponses: 3
    Dernier message: 08/12/2010, 14h23
  3. [MySQL] Grouper les resultats par date
    Par isitien dans le forum PHP & Base de données
    Réponses: 13
    Dernier message: 30/09/2009, 11h12
  4. Réponses: 2
    Dernier message: 08/05/2008, 12h36
  5. Debutant - Requête Grouper par Date
    Par ghan77 dans le forum Bases de données
    Réponses: 3
    Dernier message: 06/12/2005, 17h07

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