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

Langage SQL Discussion :

Sql retournant le 1er usage de chaque enregistrement


Sujet :

Langage SQL

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Mars 2007
    Messages
    6
    Détails du profil
    Informations personnelles :
    Localisation : France, Deux Sèvres (Poitou Charente)

    Informations forums :
    Inscription : Mars 2007
    Messages : 6
    Par défaut Sql retournant le 1er usage de chaque enregistrement
    Bonjour
    SQL 3
    Je souhaite récupérer le premier ID_USAGE_OBJET de chaque ID_OBJET de la table OBJET

    ID_OBJET ID_USAGE_OBJET
    1 "A"
    1 "D"
    1 "B"
    2 "B"
    2 "A"
    3 "C"
    3 "D"

    le résultat serait donc

    ID_OBJET ID_USAGE_OBJET
    1 "A"
    2 "B"
    3 "C"

  2. #2
    Modérateur
    Avatar de al1_24
    Homme Profil pro
    Retraité
    Inscrit en
    Mai 2002
    Messages
    9 134
    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 134
    Par défaut
    Il manque une information dans votre table pour déterminer l'ordre des lignes.
    Par définition, une table n'est pas ordonnée, à la différence d'un fichier ou d'un tableau.
    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
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Mars 2007
    Messages
    6
    Détails du profil
    Informations personnelles :
    Localisation : France, Deux Sèvres (Poitou Charente)

    Informations forums :
    Inscription : Mars 2007
    Messages : 6
    Par défaut
    le tableau obtenu est le résultat d'un select sur une table.
    Il n'y a pas d'ordre de tri.
    J'ai une base de données sur des étangs (Table ETANG).
    J'ai une table USAGE (nomenclature des usages des étangs de la lettre "A" à "F" avec les libellés qui vont bien).
    Un étang peu avoir plusieurs usages. Il me faut donc une table intermédiaire entre ETANG et USAGE batisée USAGES_ETANG qui contient l'ID_ETANG et l'ID_USAGE.
    Comment je récupère le premier usage de chaque étang (trié ou pas) ?

  4. #4
    Modérateur
    Avatar de al1_24
    Homme Profil pro
    Retraité
    Inscrit en
    Mai 2002
    Messages
    9 134
    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 134
    Par défaut
    Citation Envoyé par titidev Voir le message
    le tableau obtenu est le résultat d'un select sur une table.
    Il n'y a pas d'ordre de tri.
    Si le SGBD utilisé est conforme au standard, une nouvelle exécution de la même requête pourra donner un résultat différent, puisqu'il n'y a pas d'ordre de tri.
    La notion de premier est donc ici sans aucune signification.
    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.

  5. #5
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Mars 2007
    Messages
    6
    Détails du profil
    Informations personnelles :
    Localisation : France, Deux Sèvres (Poitou Charente)

    Informations forums :
    Inscription : Mars 2007
    Messages : 6
    Par défaut
    OK, donc l'ordre de tri est ID_OBJET puis ID_USAGE_OBJET

    Au lieu d'avoir
    ID_OBJET ID_USAGE_OBJET
    1 "A"
    1 "D"
    1 "B"
    2 "B"
    2 "A"
    3 "C"
    3 "D"

    On aura
    ID_OBJET ID_USAGE_OBJET
    1 "A"
    1 "B"
    1 "D"
    2 "A"
    2 "B"
    3 "C"
    3 "D"

    et donc le résultat souhaité sera
    ID_OBJET ID_USAGE_OBJET
    1 "A"
    2 "A"
    3 "C"

    Et la requête SQL est .....

  6. #6
    Modérateur
    Avatar de al1_24
    Homme Profil pro
    Retraité
    Inscrit en
    Mai 2002
    Messages
    9 134
    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 134
    Par défaut
    En sachant cela, c'est beaucoup plus simple, le premier c'est le plus petit dans l'ordre de tri !
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    SELECT  id_objet
        ,   MIN(id_usage_objet)
    FROM    matable
    GROUP BY    id_objet
    Je t'encourage à consulter le
    Cours SQL
    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.

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

Discussions similaires

  1. Réponses: 6
    Dernier message: 11/07/2012, 14h52
  2. Réponses: 3
    Dernier message: 04/07/2012, 13h33
  3. Sql retournant le 1er usage de chaque enregistrement
    Par titidev dans le forum Requêtes et SQL.
    Réponses: 5
    Dernier message: 28/02/2008, 00h39
  4. Ne pas retourner le 1er enregistrement d'une liste
    Par Yadutaf dans le forum Requêtes
    Réponses: 5
    Dernier message: 12/04/2007, 08h34
  5. Réponses: 8
    Dernier message: 24/08/2004, 22h25

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