gpt4 book ai didi

MySQL 使用 Disitinct 进行选择,以及使用 is_null 在哪里进行选择?

转载 作者:行者123 更新时间:2023-11-30 00:11:45 24 4
gpt4 key购买 nike

有人可以解释一下这个 MySQL 查询及其作用吗?

据我了解,它执行以下操作:

选择发票表中没有条目的invoices_charge发票id。这是正确的吗?

SELECT DISTINCT invoice_charges.invoiceid as invoice
FROM `invoice_charges`
LEFT JOIN `invoice`
ON invoice_charges.invoiceid = invoice.invoiceid
WHERE invoice.invoiceid IS NULL

关键字 DISTINCT 在此查询中是否有任何影响?以下查询是否是此查询的更好替代方案,可以实现相同的结果?

SELECT invoice_charges.invoiceid as invoice
FROM `invoice_charges`
WHERE invoice_charges.invoiceid NOT IN invoice.invoiceid
GROUP BY invoice_charges.invoiceid

最佳答案

此查询返回 invoice_charges 中与 invoice 不匹配的所有 invoiceid

据推测,这些都是外键关系失败的示例。

distinct 的目的是防止结果集中出现重复项。 invoice_charges 中可能有两条具有相同 invoiceid 的记录,其中 invoiceid 不在 invoice 表中。

关于MySQL 使用 Disitinct 进行选择,以及使用 is_null 在哪里进行选择?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/23986587/

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