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

Requêtes MySQL Discussion :

SELECT de categories dans une table


Sujet :

Requêtes MySQL

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éclairé Avatar de Sayrus
    Profil pro
    Inscrit en
    Décembre 2005
    Messages
    899
    Détails du profil
    Informations personnelles :
    Âge : 40
    Localisation : Belgique

    Informations forums :
    Inscription : Décembre 2005
    Messages : 899
    Par défaut SELECT de categories dans une table
    Bonjour,

    Question assez facile pour les experts je pense:

    Comment faire en une seule requête, un SELECT de tous les enregistrements ayant comme parentCat=0 et pour ces enregistrements, toutes leurs catégories enfants, le tout classé par catégorie et sous-catégorie?

    Ex:

    ID | category_name | parentCat |

    1 une catégorie 0
    2 Sous-cat de 1 1
    3 Sous-cat de 1 1
    4 Sous-cat de 3 3
    5 1 autre catégorie 0
    6 Sous-cat de 5 5

    Comme résultat j'aurai:

    1 une catégorie 0
    2 Sous-cat de 1 1
    3 Sous-cat de 1 1
    5 1 autre catégorie 0
    6 Sous-cat de 5 5


    Comment réaliser cela en faisant le moins de requêtes possibles?

    Un grand merci

  2. #2
    Expert confirmé Avatar de Cybher
    Homme Profil pro
    Consultant réseaux et sécurité
    Inscrit en
    Mai 2005
    Messages
    3 281
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France

    Informations professionnelles :
    Activité : Consultant réseaux et sécurité
    Secteur : Conseil

    Informations forums :
    Inscription : Mai 2005
    Messages : 3 281
    Par défaut
    salut,

    essaie ceci :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    select a.*, b.*
    from tatable a
    join tatable b
    on a.id = b.parentcat
    where a.parentcat= 0
    order by a.id, b.id
    tu auras sur une même ligne le parent et l'enfant associé
    après il faut jouer sur ton langage de programmation pour avoir la présentation souhaitée

  3. #3
    Membre éclairé Avatar de Sayrus
    Profil pro
    Inscrit en
    Décembre 2005
    Messages
    899
    Détails du profil
    Informations personnelles :
    Âge : 40
    Localisation : Belgique

    Informations forums :
    Inscription : Décembre 2005
    Messages : 899
    Par défaut
    Citation Envoyé par Cybher Voir le message
    salut,

    essaie ceci :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    select a.*, b.*
    from tatable a
    join tatable b
    on a.id = b.parentcat
    where a.parentcat= 0
    order by a.id, b.id
    tu auras sur une même ligne le parent et l'enfant associé
    après il faut jouer sur ton langage de programmation pour avoir la présentation souhaitée
    Salut,

    Merci pour ta réponse.

    J'ai cependant un autre problème, j'ai posté ici ce que je voulais faire en simplifié pour ne pas trop embrouiller mais il faudrait en plus du "JOIN" un "INNER JOIN" de "matable" avec "matable_content".

    En effet, ma table contenant mes categories et sous-categories contient l'id mais fait appel via un INNER JOIN ... ON ... pour récupérer le titre de la catégorie en fonction de la langue.

    Donc on aurait un truc du style (matable INNER JOIN matable_content ON ...) JOIN (matable INNER JOIN matable_content ON ...)

    Comment puis-je mettre en forme cette requete?

    Je fais des tests mais rien ne m'est retourné...

    Voici ce que j'ai essayé:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    SELECT cc.title AS category_name, c.id AS category_id, scc.title AS scategory_name, sc.id AS scategory_id FROM (fbc_products AS c INNER JOIN fbc_products_content AS cc ON c.id=cc.productId) JOIN (fbc_products AS sc INNER JOIN fbc_products_content AS scc ON sc.id=scc.productId) ON c.id=sc.parentCat WHERE c.type="category" AND cc.languageId=1 ORDER BY c.id, sc.id

  4. #4
    Membre chevronné
    Inscrit en
    Septembre 2006
    Messages
    685
    Détails du profil
    Informations forums :
    Inscription : Septembre 2006
    Messages : 685
    Par défaut
    Salut,

    Cela devrait à quelque chose comme.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    SELECT cc.title AS category_name, c.id AS category_id, scc.title AS scategory_name, sc.id AS scategory_id 
    FROM fbc_products AS c 
    INNER JOIN fbc_products_content AS cc ON c.id=cc.productId
    LEFT JOIN fbc_products AS sc ON c.id=sc.parentCat
    LEFT JOIN fbc_products_content AS scc ON sc.id=scc.productId
    WHERE c.type="category" AND cc.languageId=1 
    ORDER BY c.id, sc.id

  5. #5
    Membre éclairé Avatar de Sayrus
    Profil pro
    Inscrit en
    Décembre 2005
    Messages
    899
    Détails du profil
    Informations personnelles :
    Âge : 40
    Localisation : Belgique

    Informations forums :
    Inscription : Décembre 2005
    Messages : 899
    Par défaut
    Citation Envoyé par Xunil Voir le message
    Salut,

    Cela devrait à quelque chose comme.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    SELECT cc.title AS category_name, c.id AS category_id, scc.title AS scategory_name, sc.id AS scategory_id 
    FROM fbc_products AS c 
    INNER JOIN fbc_products_content AS cc ON c.id=cc.productId
    LEFT JOIN fbc_products AS sc ON c.id=sc.parentCat
    LEFT JOIN fbc_products_content AS scc ON sc.id=scc.productId
    WHERE c.type="category" AND cc.languageId=1 
    ORDER BY c.id, sc.id
    Salut,

    Cette requête répond mieux à mes attentes, je vois qu'on est sur la bonne piste mais il y a 2 choses qui ne vont pas quand même:

    Le résultat retourné me donne les produits également (type="product") or je ne souhaiterais que le premier niveau de sous catégories.

    2e chose, il ne me retourne que les sous-catégories (et donc les produits voir premier problème juste au dessus) et pas les catégories (celles ou parentCat=0)

    Une suggestion?

  6. #6
    Membre chevronné
    Inscrit en
    Septembre 2006
    Messages
    685
    Détails du profil
    Informations forums :
    Inscription : Septembre 2006
    Messages : 685
    Par défaut
    Hum, j'ai juste remis dans l'ordre ta requête sans vraiment approfondir.

    En regardant de plus près, c'est vrai qu'il y a des choses incohérentes, notamment l'auto-jointure et relation entre c.id et sc.parentCat

    Un petit schéma simplifié de tes tables serait un plus, car là, je ne vois pas trop les relations qui doivent-être faites.

Discussions similaires

  1. Select et Ancrage dans une table
    Par Canabal dans le forum Général JavaScript
    Réponses: 2
    Dernier message: 21/07/2012, 15h26
  2. Insertion d'une selection avec Union dans une table
    Par samgan dans le forum Requêtes et SQL.
    Réponses: 1
    Dernier message: 15/08/2011, 11h04
  3. Selection des données dans une table
    Par Bouanda dans le forum VBA Access
    Réponses: 1
    Dernier message: 15/02/2008, 12h48
  4. [SQL]Select dans une table d'une autre base de données
    Par Didouille dans le forum Access
    Réponses: 3
    Dernier message: 21/12/2005, 09h00
  5. [MySQL] Affichage de valeurs par selection dans une table
    Par Flushovsky dans le forum PHP & Base de données
    Réponses: 9
    Dernier message: 16/12/2005, 17h04

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