mysql 查询1个订单 存在3件及以上商品一样的其它订单
1、需求
要查1个订单 存在3件及以上商品一样的其它订单
2、数据表
表 :order_sku
字段:order_code, sku
CREATE TABLE `order_sku` (
`id` int(10) NOT NULL,
`order_code` varchar(64) DEFAULT '',
`sku` varchar(64) DEFAULT '',
PRIMARY KEY (`id`)
) ENGINE=MyISAM DEFAULT CHARSET=utf8mb4;
INSERT INTO `test`.`order_sku`(`id`, `order_code`, `sku`) VALUES (1, 'order1', 'sku1');
INSERT INTO `test`.`order_sku`(`id`, `order_code`, `sku`) VALUES (2, 'order1', 'sku2');
INSERT INTO `test`.`order_sku`(`id`, `order_code`, `sku`) VALUES (3, 'order1', 'sku3');
INSERT INTO `test`.`order_sku`(`id`, `order_code`, `sku`) VALUES (4, 'order2', 'sku1');
INSERT INTO `test`.`order_sku`(`id`, `order_code`, `sku`) VALUES (5, 'order2', 'sku2');
INSERT INTO `test`.`order_sku`(`id`, `order_code`, `sku`) VALUES (6, 'order2', 'sku3');
INSERT INTO `test`.`order_sku`(`id`, `order_code`, `sku`) VALUES (7, 'order3', 'sku1');
id | order_code | sku |
---|---|---|
1 | order1 | sku1 |
2 | order1 | sku2 |
3 | order1 | sku3 |
4 | order2 | sku1 |
5 | order2 | sku2 |
6 | order2 | sku3 |
7 | order3 | sku1 |
3、sql
- 查询与订单order1存在3个及以上SKU相同的其它订单
SELECT
order_code
FROM
order_sku
WHERE
sku IN ( SELECT sku FROM order_sku WHERE order_code = 'order1' )
AND order_code != 'order1'
GROUP BY
order_code
HAVING
count( DISTINCT sku ) >= 3;