Bonjour,
voici ma requête:
Pour faire simple, c'est une requete qui récupère une liste de produit.
Code : Sélectionner tout - Visualiser dans une fenêtre à part
1
2
3
4
5
6
7
8
9
10
11
12 SELECT SQL_CALC_FOUND_ROWS * FROM articles INNER JOIN articles_fr ON articles_fr.ref_article2=articles.id_article WHERE articles.ref_art_cat IN (896) AND active_article = '1' AND 0 < (SELECT COUNT(*) FROM articles_filtres_values WHERE articles_filtres_values.ref_article=articles.id_article AND articles_filtres_values.ref_filtre_value='162') GROUP BY xxxxxxxxxxxxxx ORDER BY articles.sell_article DESC LIMIT 0,24
Certains produits a options sont reliés dans la même table par la colonne enfant_article. Si la valeur est a 0 c'est un parent, si elle est différente de 0 c'est un enfant. (précision: si il y a des enfants, la ligne parent sert juste à relier ces derniers, sinon si le produit n'a pas d'enfants, la valeur enfant_article est a 0 et c'est une ligne article).
Je voudrais faire un GROUP BY sur la valeur enfant article, mais avec une condition.
Si la valeur enfant_article est 0 mais le produit est un parent et il n'y a pas d'enfants, ne pas GROUP BY.
Si la valeur enfant_article est différente de 0 (donc des enfants), faire un GROUP BY sur les enfants et ne pas sélectionner le parent qui aura la valeur enfant_article a 0.
Si c'est flou ou que vous avez besoin d'infos supplémentaires, n'hésitez pas.
LL
Partager