我正在建立一个电子商务网站,但遇到了某些问题
问题
我有一个名为饮料的类别现在在这个类别下我有两个子类别,威士忌和非酒精。在非酒精饮料下,我们在父母类别中提供果汁和葡萄酒饮料,用于威士忌和非酒精饮料,而非酒精饮料则是果汁和葡萄酒的父母类别。问题是,当用户点击饮料时,我希望他们能够看到威士忌类别中的所有商品和非算名类别的孩子,但我查询以获取此类别中的产品并将它们组合在一起不是working.instead它只获得父类饮品的产品,因为没有产品
代码
public function select_from_product_page_all($cat,$level){
$que = $this->query("SELECT a.product_category_id,a.quantity, a.product_id, a.description, a.product_name, a.image, a.price, Deriv1.Count FROM `product` a LEFT OUTER JOIN (SELECT parent, COUNT(*) AS Count FROM `product_category` GROUP BY parent) Deriv1 ON a.product_category_id = Deriv1.parent WHERE a.product_category_id=" . $cat);
return $que;
}
数据库结构
产品表格列
PRODUCT_NAME,数量,价格,图像,描述,product_category_id
产品类别表格列
product_category_id,名,父
产品与类别的关系是product_category_id,product_category与父类别的关系是父列,父列中保存的是父母的product_category_id。
答案 0 :(得分:0)
我能够通过下面的查询来解决它
public function select_from_product_page_all($cat,$level){
$que = $this->query("SELECT p.product_category_id,p.quantity, p.product_id, p.description, p.product_name, p.image, p.price FROM product p
WHERE p.product_category_id IN (
SELECT c.product_category_id
FROM product_category c
WHERE c.product_category_id = " . $cat . "
UNION ALL
SELECT c2.product_category_id
FROM product_category c
LEFT JOIN product_category c2 ON c.product_category_id = c2.parent
WHERE c.product_category_id = " . $cat . "
UNION ALL
SELECT c3.product_category_id
FROM product_category c
LEFT JOIN product_category c2 ON c.product_category_id = c2.parent
LEFT JOIN product_category c3 ON c2.product_category_id = c3.parent
WHERE c.product_category_id = " . $cat . "
UNION ALL
SELECT c4.product_category_id
FROM product_category c
LEFT JOIN product_category c2 ON c.product_category_id = c2.parent
LEFT JOIN product_category c3 ON c2.product_category_id = c3.parent
LEFT JOIN product_category c4 ON c3.product_category_id = c4.parent
WHERE c.product_category_id = " . $cat . "
)
GROUP BY p.product_id");
return $que;
}