繁体   English   中英

mysql查询; 选择类别树中的所有项目

[英]mysql query; select all items in category tree

我有一个带有类别的表,其中类别可以有一个父代(是其他类别的子代)。 当我想过滤父类别ID上的项目时,我希望查询包括所有子类别。

可以说我有这个类别结构:

id || title     || parentid
1  || Sports    || 0
2  || Tennis    || 1
3  || Wimbledon || 2

现在,我在温网类别中有一篇文章。 我想显示体育类别中的所有文章。

SELECT item.* FROM #table_items AS item WHERE item.catid = 1;

上面的查询未返回“温网”类别中的文章。 这可能吗?

SELECT item.* FROM #table_items AS item,#categories as catg
WHERE item.parentid = cat.parentid;

我得到了正在寻找的解决方案。 假设我要显示ID为12的类别中的所有项目:

SELECT item.* FROM #table_items AS item
LEFT JOIN #__foc_shop_categories AS cat1 ON (cat1.id = item.catid)
LEFT JOIN #__foc_shop_categories AS cat2 ON (cat1.parentid = cat2.id)
... (and so on for more depth)

WHERE (cat1.id = 12 OR cat2.id = 12 OR ...)
GROUP BY item.id

结果为类别和嵌套类别中的所有项目。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM