mysql - 帮助查询mysql中的多对多表

标签 mysql join many-to-many

我正在尝试获取没有特定颜色的产品 ID 列表(数据库是 mysql)

这是我的表格:

product
+------------+-------------+
| product_id | description |
+------------+-------------+
|          1 | Widget 1    |
|          2 | Widget 2    |
|          3 | Widget 3    |
|          4 | Widget 4    |
|          5 | Widget 5    |
|          6 | Widget 6    |
+------------+-------------+

color
+----------+-------+
| color_id | name  |
+----------+-------+
|        1 | red   |
|        2 | black |
|        3 | white |
|        4 | green |
|        5 | blue  |
|        6 | pink  |
+----------+-------+

product_color
+------------+----------+
| product_id | color_id |
+------------+----------+
|          1 | 1        |
|          1 | 4        |
|          1 | 5        |
|          2 | 2        |
|          2 | 3        |
|          3 | 1        |
|          3 | 2        |
|          3 | 3        |
|          5 | 3        |
|          5 | 6        |
|          6 | 1        |
|          6 | 5        |
|          6 | 6        |
+------------+----------+

我想要选择所有没有颜色 4(绿色)、5(蓝色)或 6(粉色)的产品。

因此,从上表中,产品 2、3 和 4 将出现在结果集中。

我能做的最好的事情是:

SELECT product.*, GROUP_CONCAT(product_color.color_id) as color_ids
FROM product
LEFT JOIN product_color USING (product_id)
GROUP BY product.product_id

这是我的结果集:

--------------------------------------
product_id  description     color_ids
--------------------------------------
1            Widget 1        1,4,5
2            Widget 2        2,3
3            Widget 3        1,2,3
4            Widget 4        NULL
5            Widget 5        3,6
6            Widget 6        1,3,6

然后我以编程方式过滤它们,但如果可以的话,我更希望数据库完成所有工作。

最理想的是,我希望我的结果集看起来像这样(我需要的只是产品 ID)。

------------
product_id 
------------
2 
3 
4 

这是架构和数据,以防您的好心人愿意帮助我。

CREATE TABLE IF NOT EXISTS `color` (
  `color_id` int(10) unsigned NOT NULL auto_increment,
  `name` varchar(25) NOT NULL,
  PRIMARY KEY  (`color_id`),
  UNIQUE KEY `name` (`name`)
) ENGINE=InnoDB  DEFAULT CHARSET=latin1 AUTO_INCREMENT=7 ;

INSERT INTO `color` (`color_id`, `name`) VALUES
(2, 'black'),
(5, 'blue'),
(4, 'green'),
(6, 'pink'),
(1, 'red'),
(3, 'white');

CREATE TABLE IF NOT EXISTS `product` (
  `product_id` int(10) unsigned NOT NULL auto_increment,
  `description` varchar(25) NOT NULL,
  PRIMARY KEY  (`product_id`),
  UNIQUE KEY `description` (`description`)
) ENGINE=InnoDB  DEFAULT CHARSET=latin1 AUTO_INCREMENT=7 ;

INSERT INTO `product` (`product_id`, `description`) VALUES
(1, 'Widget 1'),
(2, 'Widget 2'),
(3, 'Widget 3'),
(4, 'Widget 4'),
(5, 'Widget 5'),
(6, 'Widget 6');

CREATE TABLE IF NOT EXISTS `product_color` (
  `product_id` int(10) unsigned NOT NULL,
  `color_id` int(10) unsigned NOT NULL,
  PRIMARY KEY  (`product_id`,`color_id`),
  KEY `color_id` (`color_id`)
) ENGINE=InnoDB DEFAULT CHARSET=latin1;

INSERT INTO `product_color` (`product_id`, `color_id`) VALUES
(1, 1),
(3, 1),
(6, 1),
(2, 2),
(3, 2),
(2, 3),
(3, 3),
(5, 3),
(1, 4),
(1, 5),
(6, 5),
(5, 6),
(6, 6);

最佳答案

我认为 where 子句中的子查询应该足够了。

SELECT DISTINCT product_id 
FROM product  
WHERE product_id NOT IN (SELECT product_id FROM product_color WHERE color_id IN (4, 5, 6)); 

编辑:我刚刚看到了多对多位!这有效。

关于mysql - 帮助查询mysql中的多对多表,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3783192/

相关文章:

mysql - 如何在 Xampp 中升级 MariaDB

php - 为什么在使用 PHP 和 MySQL 的浏览器上不显示字母 'ST'

php - 移动地理定位 mysql windows azure

mysql - 表中的自连接和递归选择

c# - 允许多对多重复吗?

java - 如何阻止 hibernate 在 ManyToMany 映射中插入表?

mysql - 当order by col有索引时,为什么mysql需要filesort?

Mysql - UPDATE JOIN 为每个条目设置一个未知值 "2147483647"

mysql - 获取 SQL 查询以在 3 个表中为空计数结果打印 0

mysql - Select * from 'many to many' SQL 关系