【发布时间】:2021-02-23 22:45:56
【问题描述】:
我在人员和订单之间有 1..n 关系。 订单可以有 ACTIVE 或 CANCELED 状态。 一个人最多可以有一个 ACTIVE 订单,但可以有无限数量的 CANCELED 订单。 假设我的联接表的内容如下所示:
要获得具有活动订单的人,我的查询只是:
select * from persons p inner join orders o on p.id = o.person_id where o.status = 'ACTIVE';
结果应该是 id 为 1 和 3 的人。这很简单。
但是现在,我需要获取所有没有任何 ACTIVE 运输的人,因此此类查询的结果应该是 id 为 2 的人(不一定必须是不同的行)。我不能只在上面的查询中更改为 != 'ACTIVE',因为这样我得到了所有这 3 个人,因为他们都有状态不是 ACTIVE 的订单。
如果我用文字来解释,我会说,对于每一行,我还需要检查具有相同 p.id 的其他行,并检查其中任何一行是否没有出现 ACTIVE 状态。
有什么建议可以实现吗?
【问题讨论】:
标签: mysql sql join subquery inner-join