sql 多对多关联查询指定关联组是否存在
在多对多关联中,有时需要判断是否存在满足特定关联条件的组。例如,判断是否有一个篮子内仅包含 2 个苹果和 1 个香蕉。
解决方法:
- 筛选出符合苹果=2、香蕉=1的篮子:
select bucket_id from 对应表 where fruit_id = 2 and count = 2 inner join select bucket_id from 对应表 where fruit_id = 3 and count = 1 on t1.bucket_id = t2.bucket_id
- 排除掉包含其他水果的篮子:
select bucket_id from t3, ( select bucket_id from 对应表 group by bucket_id having count(1) = 2 ) t4 where t3.bucket_id = t4.bucket_id
最终结果即为满足条件的篮子id,如果不存在则返回空集。需要注意的是,该sql仅适用于数据量较小的情况,在数据量较大时可能会出现性能问题。