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 :

Division relationnelle : problème avec les doublons


Sujet :

Langage SQL

  1. #1
    ced
    ced est déconnecté
    Rédacteur/Modérateur

    Avatar de ced
    Homme Profil pro
    Gestion de bases de données techniques
    Inscrit en
    Avril 2002
    Messages
    6 016
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 48
    Localisation : France, Loiret (Centre)

    Informations professionnelles :
    Activité : Gestion de bases de données techniques
    Secteur : Agroalimentaire - Agriculture

    Informations forums :
    Inscription : Avril 2002
    Messages : 6 016
    Points : 23 705
    Points
    23 705
    Par défaut Division relationnelle : problème avec les doublons
    Bonjour,

    J'ai une question à propos de la technique mise en place pour faire une division relationnelle.
    Supposons que j'ai les deux tables suivantes :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    CREATE TABLE categorie (
      id INT NOT NULL PRIMARY KEY,
      nom VARCHAR(45)
    );
    et
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    CREATE TABLE objet (
      id INT NOT NULL PRIMARY KEY,
      id_categ INT FOREIGN KEY REFERENCES categorie (id),
      taille SMALLINT
    );
    Avec les données suivantes :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    INSERT INTO categorie VALUES (1, 'categorie1');
    INSERT INTO categorie VALUES (2, 'categorie2');
    INSERT INTO categorie VALUES (3, 'categorie3');
    INSERT INTO categorie VALUES (4, 'categorie4');
    et
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    INSERT INTO objet VALUES (1, 1, 10);
    INSERT INTO objet VALUES (2, 1, 11);
    INSERT INTO objet VALUES (3, 1, 9);
    INSERT INTO objet VALUES (4, 1, 5);
    INSERT INTO objet VALUES (5, 2, 6);
    INSERT INTO objet VALUES (6, 2, 8);
    INSERT INTO objet VALUES (7, 2, 6);
    INSERT INTO objet VALUES (8, 2, 4);
    INSERT INTO objet VALUES (9, 3, 5);
    INSERT INTO objet VALUES (10, 4, 8);
    INSERT INTO objet VALUES (11, 4, 10);
    INSERT INTO objet VALUES (12, 4, 12);
    INSERT INTO objet VALUES (13, 4, 10);
    Maintenant, je souhaite les deux plus gros objets de chaque catégorie. Je fais ça par une division relationnelle, comme suit :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    SELECT o.id, c.nom, o.taille
    FROM objet o
    INNER JOIN categorie c ON o.id_categ = c.id
    WHERE (SELECT COUNT(*)
           FROM objet o2
           WHERE o.id_categ = o2.id_categ
           AND o.taille < o2.taille) < 2
    ORDER BY o.id
    Comme on peut le voir, on obtient bien 2 objets de la catégorie 1, un seul de la catégorie 3 (le seul de cette catégorie), mais 3 objets pour les catégories 2 et 4. Cela est dû au fait qu'il y a des objets de même taille (la deuxième plus grande taille dans ces catégories).
    Ma question est la suivante : dans les catégories 2 et 4, comment faire pour ne ramener qu'un seul des objets en double (par exemple celui qui a le plus petit id) ?

    Merci d'avance de votre aide,

    ced
    Rédacteur / Modérateur SGBD et R
    Mes tutoriels et la FAQ MySQL

    ----------------------------------------------------
    Pensez aux balises code et au tag
    Une réponse vous a plu ? N'hésitez pas à y mettre un
    Je ne réponds pas aux questions techniques par message privé, les forums sont là pour ça

  2. #2
    J1
    J1 est déconnecté
    Membre averti Avatar de J1
    Inscrit en
    Mai 2004
    Messages
    321
    Détails du profil
    Informations forums :
    Inscription : Mai 2004
    Messages : 321
    Points : 335
    Points
    335
    Par défaut
    Bonjour,

    malheureusement, tu n'indiques pas ton SGBD. Voici toujours une solution sous SQL Server 2000 :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
     
    SELECT o.id, c.nom, o.taille
    FROM objet o
    INNER JOIN categorie c ON o.id_categ = c.id
    WHERE o.id IN (
    	SELECT TOP 2 id
    	FROM objet
    	WHERE id_categ=o.id_categ
    	ORDER BY taille DESC, id ASC)

  3. #3
    ced
    ced est déconnecté
    Rédacteur/Modérateur

    Avatar de ced
    Homme Profil pro
    Gestion de bases de données techniques
    Inscrit en
    Avril 2002
    Messages
    6 016
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 48
    Localisation : France, Loiret (Centre)

    Informations professionnelles :
    Activité : Gestion de bases de données techniques
    Secteur : Agroalimentaire - Agriculture

    Informations forums :
    Inscription : Avril 2002
    Messages : 6 016
    Points : 23 705
    Points
    23 705
    Par défaut
    Bonjour et merci pour cette réponse.
    En fait, si je n'ai pas indiqué de SGBD, c'est parce que j'espère une solution en SQL pur (je sais, je suis difficile )...
    J'ai bien pensé à limiter le nombre de lignes, mais cette synthaxe varie avec les SGBD, et tous n'acceptent pas forcément de limiter les lignes dans une sous-requête avec un IN (MySQL par exemple), d'où ma volonté de m'affranchir du SGBD...

    En tout cas, merci pour l'aide sous SQL Server. Ca en fait toujours un...

    ced
    Rédacteur / Modérateur SGBD et R
    Mes tutoriels et la FAQ MySQL

    ----------------------------------------------------
    Pensez aux balises code et au tag
    Une réponse vous a plu ? N'hésitez pas à y mettre un
    Je ne réponds pas aux questions techniques par message privé, les forums sont là pour ça

  4. #4
    J1
    J1 est déconnecté
    Membre averti Avatar de J1
    Inscrit en
    Mai 2004
    Messages
    321
    Détails du profil
    Informations forums :
    Inscription : Mai 2004
    Messages : 321
    Points : 335
    Points
    335
    Par défaut
    Je dois dire que la sous-requête en SELECT COUNT n'est pas la méthode que j'emploie habituellement pour mes requêtes de type "TOP n par groupe".
    Mais je comprends tes impératifs, donc si on décide de conserver le principe du COUNT, pourquoi ne pas essayer ceci :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
     
    SELECT o.id, c.nom, o.taille
    FROM objet o
    INNER JOIN categorie c ON o.id_categ = c.id
    WHERE (
      SELECT COUNT(*)
      FROM objet
      WHERE id_categ = o.id_categ
        AND (taille > o.taille
          OR (taille = o.taille AND id < o.id))) < 2
    ORDER BY o.id
    Voilà juste pour l'idée. A affiner si [taille] peut être NULL.

  5. #5
    ced
    ced est déconnecté
    Rédacteur/Modérateur

    Avatar de ced
    Homme Profil pro
    Gestion de bases de données techniques
    Inscrit en
    Avril 2002
    Messages
    6 016
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 48
    Localisation : France, Loiret (Centre)

    Informations professionnelles :
    Activité : Gestion de bases de données techniques
    Secteur : Agroalimentaire - Agriculture

    Informations forums :
    Inscription : Avril 2002
    Messages : 6 016
    Points : 23 705
    Points
    23 705
    Par défaut
    Bien joué .
    Effectivement, et si taille peut être NULL, on le remplace par une valeur quelconque (petite de préférence) via un coalesce (ou toute fonction équivalente)...

    Ca répond à ma question.

    Merci beaucoup

    ced
    Rédacteur / Modérateur SGBD et R
    Mes tutoriels et la FAQ MySQL

    ----------------------------------------------------
    Pensez aux balises code et au tag
    Une réponse vous a plu ? N'hésitez pas à y mettre un
    Je ne réponds pas aux questions techniques par message privé, les forums sont là pour ça

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

Discussions similaires

  1. Problème avec les doublons
    Par Victor1 dans le forum Excel
    Réponses: 6
    Dernier message: 08/07/2013, 12h28
  2. Probléme avec les doublons
    Par benlakhel dans le forum Shell et commandes POSIX
    Réponses: 4
    Dernier message: 05/02/2013, 10h40
  3. [XL-2007] Problème avec les doublons
    Par Mammy Potter dans le forum Macros et VBA Excel
    Réponses: 2
    Dernier message: 15/02/2011, 12h17
  4. Probléme avec les doublons
    Par albatof dans le forum SQLite
    Réponses: 2
    Dernier message: 16/06/2008, 16h40
  5. []Problème avec les formulaires Outlook
    Par davidinfo dans le forum Outlook
    Réponses: 6
    Dernier message: 05/12/2002, 09h59

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