gpt4 book ai didi

MySQL SELECT 与多个相似行不同

转载 作者:行者123 更新时间:2023-11-29 00:03:26 28 4
gpt4 key购买 nike

我很难返回正确的数据,我有一个具有以下数据结构的表:

# order_id, name
'10434', 'docs_sent'
'10433', 'placed'
'10433', 'docs_sent'
'10433', 'agreement_received'
'10432', 'placed'
'10431', 'placed'
'10431', 'docs_sent'
'10430', 'placed'
'10430', 'docs_sent'
'10430', 'agreement_received'
'10429', 'placed'
'10429', 'docs_sent'
'10429', 'agreement_received'
'10428', 'placed'
'10428', 'docs_sent'
'10427', 'placed'

我想做的是返回一个唯一的“order_id”,其中“name”不包括 agreement_received。因此,为了澄清,我正在寻找订单号列表“order_id”,其中订单号没有任何带有 agreement_received 的记录。问题是每个订单都有多个条目,我似乎无法正确处理。请帮助!

输出应该类似于:

# order_id
'10434'
'10432'
'10431'
'10428'
'10427'

最佳答案

您想按 order_id分组并且只保留那些没有“agreement_received”记录的 order_id。

select order_id
from mytable
group by order_id
having sum(name = 'agreement_received') = 0;

(这使用了 MySQL 的特殊 bool 处理。False = 0,True = 1。在其他 dbms 中,您必须使用 sum(case when name = 'agreement_received' then 1 else 0 end)。 )

关于MySQL SELECT 与多个相似行不同,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28660144/

28 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com