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;
posted @ 2023-03-17 16:45  pine007  阅读(130)  评论(0编辑  收藏  举报