MySQL查询表可能有也可能没有数据

时间:2011-09-14 17:29:54

标签: mysql database

我有两张桌子:一张用于交易,一张用于账单。它可能是产生账单的一般交易。可能没有批准的交易不会产生账单。

问题是我想要打印两个表的信息,但是不可能看到是否有(或没有)账单。

一些代表字段来自:

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”匹配的信息,但问题是WONT打印没有账单的交易 - 因为,你没有userId匹配 - < / p>

如果我放松在哪里,它会打印几次相同的信息:/

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

有什么想法解决这个问题吗?

1 个答案:

答案 0 :(得分:3)

在这种情况下,您想要使用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