MySQL 在同一列上使用 AND 运算符多个 WHERE IN

标签 mysql where-in

需要一些有关 MySQL 的帮助。

我正在构建网上商店,但在使用同一列上的多个 WHERE IN 子句过滤搜索结果时遇到问题。

我有表shopitemfilterfilter_optionshopitem_option

shopitem(商品名称、描述、价格等)

id
title
price

过滤器(主要过滤器类别,如颜色、品牌、性别、尺寸等)

id
name

filter_option(过滤器选项,如尺寸(S、M、L)、颜色(黑色、白色)等)

id
name
filter_id (filter.id)

shopitem_option(商品和选项之间的连接)

id
shopitem_id (shopitem.id)
filter_id (filter.id)
filter_option_id (filter_option.id)

我有各种不同尺寸、颜色、性别等的 Nike Air 鞋等商品...

所以在 shopitem_option 表中我有以下内容:

id  |  shopitem_id  |  filter_id  |  filter_option_id
-----------------------------------------------------
1   |  Nike Air     |  Color      |  black
2   |  Nike Air     |  Color      |  white
3   |  Nike Air     |  Size       |  40
4   |  Nike Air     |  Size       |  41
5   |  Nike Air     |  Size       |  42
6   |  Nike Air     |  Gender     |  man

当我创建 MySQL 查询时,它需要是这样的(在纯 SQL 查询中而不是“black”、“men”等。有 filter_option.id 字段的 ID)

SELECT shopitem.*
FROM shopitem
LEFT JOIN shopitem_option.shopitem_id = shopitem.id
WHERE
    shopitem_option.filter_option_id IN (black) AND 
    shopitem_option.filter_option_id IN (41,42) AND 
    shopitem_option.filter_option_id IN (man)

但这不起作用。如果我仅搜索尺码 40,或仅搜索黑色,它将返回所有尺码 40 的鞋子或所有黑色的鞋子。但是,如果我组合过滤器来搜索颜色为黑色且尺寸为 40 的项目,它将返回空查询结果。

所以,基本上用户可以搜索鞋子在哪里颜色(黑色OR白色)尺码>(41 OR 42) AND 性别(男性)。我怎样才能做到这一点?

最佳答案

IN ... AND IN ... 在这里不起作用,因为您告诉数据库选择 shopitem_option,其中 filter_option_id 应为 black41 对于同一条记录。像这样使用 EXISTS:

SELECT *
  FROM shopitem i
 WHERE EXISTS (SELECT 1 FROM shopitem_option o WHERE i.id = o.shopitem_id AND o.filter_option_id IN (black))
   AND EXISTS (SELECT 1 FROM shopitem_option o WHERE i.id = o.shopitem_id AND o.filter_option_id IN (41, 42))
   AND EXISTS (SELECT 1 FROM shopitem_option o WHERE i.id = o.shopitem_id AND o.filter_option_id IN (man))

关于MySQL 在同一列上使用 AND 运算符多个 WHERE IN,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33755278/

相关文章:

PHP表格查询展示前端

MySQL SELECT 对存储过程中的 NOT NULL 列返回 NULL

php - 我可以将数组绑定(bind)到 PDO 查询中的 IN() 条件吗?

mysql - 如何对两个单独的表使用 mysql WHERE IN

java - SQL(和 Javax.Persistence.Query.ExecuteQuery)如何将 UPDATE 与 WHERE-IN 和 AND 一起使用

php - Yii2 事件记录中按查询等效的 MySQL 复杂顺序

mysql - 为什么我的订单不区分大小写,因为未能正确排序结果?

Mysql 两个亚马逊实例之间的通信

Java 将值传递到 SQL WHERE 子句中的 IN

mysql - 将 Laravel 查询生成器方法 whereIn() 与子查询一起使用