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 :

SELECT suivant le nombre de lignes d'une colonne [2012]


Sujet :

MS SQL Server

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Homme Profil pro
    Étudiant
    Inscrit en
    Mai 2011
    Messages
    24
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Hauts de Seine (Île de France)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Mai 2011
    Messages : 24
    Par défaut SELECT suivant le nombre de lignes d'une colonne
    Bonjour à tous,

    Je viens vers vous aujourd'hui pour m'aider à résoudre ce petit problème.

    J'ai une table de liaison que voici:
    id id2
    1 1
    6 1
    7 2
    8 2
    8 3
    9 1
    9 2
    10 1
    11 1
    11 3

    J'aimerai faire un SELECT des id qui n'apparaisent qu'une fois et dont l'id2 = 1. En gros, je voudrais ça:
    id id2
    1 1
    6 1
    10 1

    Avez vous des idées comment faire?
    Merci d'avance

    PS: j'ai essayer cette requete, mais je n'ai que la première partie de mon problème.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    SELECT id, id2 FROM table
    WHERE idjeux = 7
    GROUP BY id
    HAVING COUNT(id2) = 1

  2. #2
    Membre éclairé
    Homme Profil pro
    Chef de projet BI
    Inscrit en
    Août 2013
    Messages
    42
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Val d'Oise (Île de France)

    Informations professionnelles :
    Activité : Chef de projet BI

    Informations forums :
    Inscription : Août 2013
    Messages : 42
    Par défaut
    J'espère avoir compris ton besoin, je pense qu'il te faut utiliser une sous requête du type :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
     
    SELECT ID1, ID2
    FROM TABLE
    WHERE ID1 IN (SELECT ID1
                  FROM TABLE
                  GROUP BY ID1
                  HAVING COUNT(ID1) = 1)
    AND ID2 = 1

  3. #3
    Expert confirmé
    Avatar de StringBuilder
    Homme Profil pro
    Chef de projets
    Inscrit en
    Février 2010
    Messages
    4 197
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 46
    Localisation : France, Rhône (Rhône Alpes)

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

    Informations forums :
    Inscription : Février 2010
    Messages : 4 197
    Billets dans le blog
    1
    Par défaut
    Pas besoin de faire de jointure avec le sous-select.

    Code sql : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
     
    select *
    from (
      SELECT ID1
      FROM TABLE
      GROUP BY ID1
      HAVING COUNT(ID1) = 1
    ) tmp
    where tmp.id = 1

  4. #4
    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
    ou sans sous requête, donc peut-être un peu plus performant :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
     
    SELECT 
    	id1, 1 as id2
    FROM LaTable
    GROUP BY id1
    HAVING COUNT(*) = 1
    AND MAX(CASE WHEN id2 = 1 THEN 1 END) = 1

  5. #5
    Expert confirmé
    Avatar de StringBuilder
    Homme Profil pro
    Chef de projets
    Inscrit en
    Février 2010
    Messages
    4 197
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 46
    Localisation : France, Rhône (Rhône Alpes)

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

    Informations forums :
    Inscription : Février 2010
    Messages : 4 197
    Billets dans le blog
    1
    Par défaut
    Effectivement

    Cependant, avec SQL Server 2014, j'ai été très surpris tout à l'heure de voir qu'une auto-jointure sur une sous-requête faisait un plan d'exécution avec une seule lecture dans la table.

    Du coup, je me demande si avec SQL Server 2014, si ça se trouve, on a le même plan d'exécution pour les 3 requêtes

  6. #6
    Membre averti
    Homme Profil pro
    Étudiant
    Inscrit en
    Mai 2011
    Messages
    24
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Hauts de Seine (Île de France)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Mai 2011
    Messages : 24
    Par défaut
    En fait, j'utiliserai cette requete déjà en tant que sous-requete.
    Ca va faire lourd si je mets une seconde sous requete non?

    Merci aieeeuuuuu, je vais prendre cette requete là

  7. #7
    Membre averti
    Homme Profil pro
    Étudiant
    Inscrit en
    Mai 2011
    Messages
    24
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Hauts de Seine (Île de France)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Mai 2011
    Messages : 24
    Par défaut
    Dernière question,
    Si je veux uniquement ceux qui ont deux lignes, j'ai repris la requete de aieeeuuuuu, mais est-ce qu'il y a plus simple?

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    SELECT id1
    FROM MaTable
    GROUP BY id1
    HAVING COUNT(*) = 2
    AND MAX(CASE WHEN id2 = 1 THEN 1 END) = 1
    AND MAX(CASE WHEN id2 = 3 THEN 3 END) = 3

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

Discussions similaires

  1. [Excel][VB.NET] Nombre de ligne dans une colonne
    Par hunteshiva dans le forum VB.NET
    Réponses: 1
    Dernier message: 11/11/2011, 21h57
  2. [XL-2007] connaître le nombre de ligne dans une colonne
    Par EFFLYINGJOKER dans le forum Excel
    Réponses: 3
    Dernier message: 17/05/2011, 09h08
  3. nombre de lignes contenant une colonne dans une feuille
    Par bonanos dans le forum Macros et VBA Excel
    Réponses: 2
    Dernier message: 09/07/2009, 16h43
  4. Etirer une formule suivant le nombre de ligne d'une autre feuille
    Par S l i d e dans le forum Macros et VBA Excel
    Réponses: 7
    Dernier message: 11/08/2007, 23h45
  5. Nombre de lignes <> '' dans une colonne Excel
    Par zemeilleurofgreg dans le forum Delphi
    Réponses: 5
    Dernier message: 10/07/2007, 15h22

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