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 :

extraction des lignes en double ou plus seulement


Sujet :

Développement SQL Server

  1. #1
    Membre régulier
    Profil pro
    Inscrit en
    Octobre 2006
    Messages
    430
    Détails du profil
    Informations personnelles :
    Localisation : Canada

    Informations forums :
    Inscription : Octobre 2006
    Messages : 430
    Points : 103
    Points
    103
    Par défaut extraction des lignes en double ou plus seulement
    Bonjour

    J'aimerais extraire toutes les lignes d'une table T1 qui ont le champ c1 plus qu'une fois.

    Exemple :

    c1 c2 c3 c4
    10 25 6 45
    10 14 7 87
    10 5 25 88
    11 14 58 47
    13 14 58 68
    dans ce cas j'aimerais obtenir le résultat suivant :

    10 25 6 45
    10 14 7 87
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    select c1, c2, c3, c4
    from T1
    where c2 > 10 et c3 < 8
    Group by c1 > 2
    having ...
    Merci de votre aide.

  2. #2
    Rédacteur

    Avatar de SQLpro
    Homme Profil pro
    Expert bases de données / SQL / MS SQL Server / Postgresql
    Inscrit en
    Mai 2002
    Messages
    21 761
    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 : 21 761
    Points : 52 547
    Points
    52 547
    Billets dans le blog
    5
    Par défaut
    Il existe des dizaines de façon d'écrire cette requête. Mais comme vous n'avez pas respecté la charte de postage et donc pas donné la structure de la table il est difficile de vous donner la meilleures...

    Voici une solution :

    Jeu d'essai :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    CREATE TABLE T1 (C1 INT, C2 INT, C3 INT, C4 INT)
     
    INSERT INTO T1 
    VALUES (10, 25,  6, 45),
           (10,  5, 25, 88),
           (10, 14,  7, 87),
           (11, 14, 58, 47),
           (13, 14, 58, 68);
    Solution :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    SELECT * 
    FROM   T1 AS T2
    WHERE  EXISTS(SELECT 1
                      FROM   T1 AS T3
                      WHERE  T3.C1 = T2.C1
                      GROUP  BY C1
                      HAVING COUNT(*) = 1)
    UNION
    SELECT *
    FROM   T1 AS T2
    WHERE  EXISTS (SELECT * 
                   FROM   T1  AS T3
                   WHERE  T2.C1 = T3.C1
                     AND  T2.C2 > T3.C2)
    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/ * * * * *

  3. #3
    Membre régulier
    Profil pro
    Inscrit en
    Octobre 2006
    Messages
    430
    Détails du profil
    Informations personnelles :
    Localisation : Canada

    Informations forums :
    Inscription : Octobre 2006
    Messages : 430
    Points : 103
    Points
    103
    Par défaut
    Il me semble que c'est un peu plus compliquer de ce que je cherche, de plus, je l'ai essayé et ca ne me donne pas le résultat escompté.

    Citation Envoyé par SQLpro Voir le message
    Il existe des dizaines de façon d'écrire cette requête. Mais comme vous n'avez pas respecté la charte de postage et donc pas donné la structure de la table il est difficile de vous donner la meilleures...

    Voici une solution :

    Jeu d'essai :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    CREATE TABLE T1 (C1 INT, C2 INT, C3 INT, C4 INT)
     
    INSERT INTO T1 
    VALUES (10, 25,  6, 45),
           (10,  5, 25, 88),
           (10, 14,  7, 87),
           (11, 14, 58, 47),
           (13, 14, 58, 68);
    Solution :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    SELECT * 
    FROM   T1 AS T2
    WHERE  EXISTS(SELECT 1
                      FROM   T1 AS T3
                      WHERE  T3.C1 = T2.C1
                      GROUP  BY C1
                      HAVING COUNT(*) = 1)
    UNION
    SELECT *
    FROM   T1 AS T2
    WHERE  EXISTS (SELECT * 
                   FROM   T1  AS T3
                   WHERE  T2.C1 = T3.C1
                     AND  T2.C2 > T3.C2)
    A +

  4. #4
    Rédacteur

    Avatar de SQLpro
    Homme Profil pro
    Expert bases de données / SQL / MS SQL Server / Postgresql
    Inscrit en
    Mai 2002
    Messages
    21 761
    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 : 21 761
    Points : 52 547
    Points
    52 547
    Billets dans le blog
    5
    Par défaut
    D'où intérêt encore une fois de respecter la charte de postage. En ne le faisant pas vous nous faites travailler gratuitement et en vain.
    http://www.developpez.net/forums/d96...vement-poster/
    C'est du temps perdu pour vous et moi, en plus d'être impoli !

    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/ * * * * *

  5. #5
    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
    Points : 13 092
    Points
    13 092
    Par défaut
    Bonjour
    essayez peut être ceci alors

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
           SELECT C1,C2,C3,C4
           FROM (
               SELECT *,  COUNT(*) OVER (PARTITION BY C1 ) AS NbC1
               FROM T1
           ) tmp
           WHERE NbC1 > 1

  6. #6
    Membre régulier
    Profil pro
    Inscrit en
    Octobre 2006
    Messages
    430
    Détails du profil
    Informations personnelles :
    Localisation : Canada

    Informations forums :
    Inscription : Octobre 2006
    Messages : 430
    Points : 103
    Points
    103
    Par défaut
    Merci bien aieeeuuuuu, ceci me donne le bon résultat.

    Par la même occasion, j'aimerais dire à SQLPro que je ne suis pas une personne impolie et je demande qu'il présente des excuses.

    Merci.

  7. #7
    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
    Points : 13 092
    Points
    13 092
    Par défaut
    Ce que SQL-Pro entendait par impoli était le fait de ne pas respecter la charte du forum, qui vous indique par ailleurs de placer le sujet a "résolu" lorsque celui-ci est... résolu.

    Ceci fait aussi gagner du temps aux volontaires qui apportent des réponses, qui ne perdront pas leur temps à lire tout un sujet pour se rendre compte finalement qu'une solution à déjà été trouvée.

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

Discussions similaires

  1. [AC-2007] Extraction des lignes
    Par abdellatifalaoui dans le forum VBA Access
    Réponses: 1
    Dernier message: 03/11/2011, 07h50
  2. [Langage/Algorithme] Extraction des ligne d'un texte manuscrit
    Par pink23 dans le forum C++Builder
    Réponses: 7
    Dernier message: 25/08/2010, 18h09
  3. extraction des lignes
    Par afef_master dans le forum Traitement d'images
    Réponses: 8
    Dernier message: 22/12/2009, 11h55
  4. Extraction des lignes d'un fichier sous forme de chaine
    Par rahalfat10 dans le forum Langage
    Réponses: 8
    Dernier message: 05/01/2009, 15h40
  5. Supprimer des lignes en double.
    Par Empty_body dans le forum Langage SQL
    Réponses: 3
    Dernier message: 05/06/2007, 14h45

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