gpt4 book ai didi

带有可能有或可能没有数据的表的 MySQL 查询

转载 作者:搜寻专家 更新时间:2023-10-30 22:18:44 24 4
gpt4 key购买 nike

我有两张表:一张用于交易,一张用于账单。它可以是生成账单的批准交易。可能存在不生成账单的未批准交易。

问题是我想打印两个表的信息,但无法查看是否有(或没有)账单。

部分代表字段来自:

Transactions:  service_bill, auth_number, UserId ...
Bill: UserId, ...

当我进行查询时:

    SELECT *
FROM transactions, bill
WHERE MONTH(date) = '09'
AND
YEAR(date) = 2011
(...)
AND
bill.userId = transactions.userId
(...)
ORDER BY id_transaction

如果我使用该查询,我将打印与“userId”匹配的信息,但问题是它不会打印没有账单的交易 - 因为,您没有要匹配的 userId-

如果我放松 where,它会多次打印相同的信息:/

最后,我想打印所有信息 - 不重复 - 在未生成的账单中,当显示交易时,账单信息为 NULL 或类似信息。

有解决办法吗?

最佳答案

在这种情况下,您想使用 LEFT JOIN。这将返回第一个表中的所有行以及在第二个表中找到的任何匹配项。任何不匹配的行都将为第二个表的列返回 NULL 值。

SELECT *
FROM transactions t
LEFT JOIN bill b
ON t.userId = b.userId
WHERE MONTH(date) = '09'
AND YEAR(date) = 2011
(...)
ORDER BY t.id_transaction

关于带有可能有或可能没有数据的表的 MySQL 查询,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7420463/

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