2

我知道 mySQL 5.x 不支持 INTERSECT,但这似乎是我需要的。

表 A:产品 (p_id)

表 B:Prod_cats (cat_id) - 类别信息(名称、描述等)

表 C:prod_2cats (p_id, cat_id) - 多对多

prod_2cats 包含已分配给产品 (A) 的许多(1 个或多个)类别。

进行查询/过滤查找(用户交互)并且需要能够跨多个类别选择满足所有条件的产品。

例如: - 80 个产品分配给类别 X - 50 个产品分配给类别 Y - 但只有 10 个产品(相交)分配给 cat X 和 cat Y

此 sql 适用于一个类别:

SELECT * FROM products WHERE p_show='Y' AND p_id IN (SELECT p_id FROM prods_2catsAS PC WHERE PC.cat_id =" . $cat_id ."

<-$cat_id 是从查询表单传递的经过净化的 var。

我似乎找不到说“给我猫 A 和猫 B 的交集”并取回子集的方法(10 条记录,来自我的示例)

帮助!

4

3 回答 3

2

嗯,我不确定这是不是最好的方法,但它可以很容易地添加到您已经存在的查询中:

SELECT *
FROM products
WHERE p_show='Y'
    AND p_id IN (SELECT p_id
                 FROM prods_2cats AS PC
                 WHERE PC.cat_id = $cat1_id)
    AND p_id IN (SELECT p_id
                 FROM prods_2cats AS PC2
                 WHERE PC2.cat_id = $cat2_id)
于 2010-04-05T20:58:55.507 回答
1
SELECT *
FROM products
WHERE p_show='Y'
    AND p_id IN (SELECT p_id
                 FROM prods_2cats AS PC
                 WHERE PC.cat_id in ($cat1_id, $cat2_id ))

或者甚至更好

SELECT p.*
FROM products p INNER JOIN prods_2cats AS PC on p.p_id = PC.p_id
WHERE p_show='Y' and C.cat_id in ($cat1_id, $cat2_id )

希望这可以帮助

于 2010-04-06T21:13:27.840 回答
1

应用集合论中的交集定义。因此,如果 X 与 Y 相交给出集合 Z,那么对于 Z 中的每个 x,它都认为 x 在 X 中并且 x 在 Y 中。

就像是

SELECT * FROM products WHERE p_show='Y' AND p_id IN 
( SELECT p_id FROM prods_2cats AS PC WHERE PC.cat_id =X) AND p_id IN
( SELECT p_id FROM prods_2cats AS PC WHERE PC.cat_id =Y)
于 2010-04-05T20:59:06.037 回答