MySQL select join where AND where

Posted

技术标签:

【中文标题】MySQL select join where AND where【英文标题】: 【发布时间】:2011-06-28 09:49:36 【问题描述】:

我的数据库中有两个表:

产品

id(整数,主键) 名称(varchar)

产品标签

product_id (int) tag_id (int)

我想选择具有所有给定标签的产品。我试过了:

SELECT
    *
FROM
    Products
JOIN ProductTags ON Products.id = ProductTags.product_id
WHERE
    ProductTags.tag_id IN (1, 2, 3)
GROUP BY
    Products.id

但它给我的产品有任何给定的标签,而不是所有给定的标签。写WHERE tag_id = 1 AND tag_id = 2 是没有意义的,因为不会返回任何行。

【问题讨论】:

我不明白你在追求什么?您愿意详细说明一些数据和示例吗? 【参考方案1】:

这类问题称为relational division

SELECT Products.* 
FROM Products
JOIN ProductTags ON Products.id = ProductTags.product_id
WHERE ProductTags.tag_id IN (1,2,3)
GROUP BY Products.id /*<--This is OK in mysql other RDBMSs 
                          would want the whole SELECT list*/

HAVING COUNT(DISTINCT ProductTags.tag_id) = 3 /*Assuming that there is a unique
                                              constraint on product_id,tag_id you 
                                              don't need the DISTINCT*/

【讨论】:

这样就解决了问题。我想知道最后一行中的数字 3 代表什么。我得到了正确的结果:HAVING COUNT(DISTINCT ProductTags.tag_id) = 1 和任何大小的标签 id 数组:WHERE ProductTags.tag_id IN (1,2,3,4) 您需要根据需要调整3。对于(1,2,3,4),您需要使用HAVING COUNT(DISTINCT ProductTags.tag_id) = 4,否则您将带回那些在4 个标签中具有任何3 个匹配标签的标签。【参考方案2】:

您需要有一个 group by / count 以确保所有内容都被考虑在内

select Products.*
  from Products 
         join ( SELECT Product_ID
                  FROM ProductTags
                  where ProductTags.tag_id IN (1,2,3)
                  GROUP BY Products.id
                  having count( distinct tag_id ) = 3 ) PreQuery
        on ON Products.id = PreQuery.product_id 

【讨论】:

【参考方案3】:

MySQL WHERE fieldname IN (1,2,3) 本质上是WHERE fieldname = 1 OR fieldname = 2 OR fieldname = 3 的简写。因此,如果您没有通过WHERE ... IN 获得所需的功能,请尝试切换到ORs。如果这仍然不能给您想要的结果,那么可能WHERE ... IN 不是您需要使用的功能。

【讨论】:

以上是关于MySQL select join where AND where的主要内容,如果未能解决你的问题,请参考以下文章

MySQL select join where AND where

mysql的inner join,left jion,right join,cross join以及on和where的区别

python 3 mysql sql逻辑查询语句执行顺序

“INNER JOIN 之前的 Sub SELECT”还是“INNER JOIN 之后的 WHERE”?

mysql查询,left join(求并集),where(求交集)

mysql:简介