1

嘿家伙希望你能帮助我。

我正在尝试进行查询,以便在三个不同的表中有一个带有外键的主表。现在我想分别计算它在所有 3 个表中的条目。这是我到目前为止所拥有的,希望你们能帮助我解决它。

SELECT box_code.id, count( box_code_unused.id ) AS total, count( box_code_used.id ) AS total2, count( box_code_expired.id ) AS total3
FROM box_code
JOIN box_code_used ON box_code_used.box_code_id = box_code.id
JOIN box_code_unused ON box_code_unused.box_code_id = box_code.id
JOIN box_code_expired ON box_code_expired .box_code_id = box_code.id
GROUP BY box_code.id

如果我只从一个表中计算条目,这种方法会起作用,但由于我从 3 个表中计算它不正确。

提前致谢。

4

3 回答 3

1

您可能会计算不同的 ID 出现次数:

SELECT box_code.id, 
       count(distinct box_code_unused.id ) AS total, 
       count(distinct box_code_used.id ) AS total2, 
       count(distinct box_code_expired.id ) AS total3
FROM box_code
LEFT JOIN box_code_used ON box_code_used.box_code_id = box_code.id
LEFT JOIN box_code_unused ON box_code_unused.box_code_id = box_code.id
LEFT JOIN box_code_expired ON box_code_expired .box_code_id = box_code.id
GROUP BY box_code.id
于 2012-08-21T10:21:46.633 回答
1

像这样使用子查询:

SELECT box_code.id, 
    (SELECT COUNT(*) FROM box_code_used b1 WHERE b1.box_code_id = box_code.id) AS total1,
    (SELECT COUNT(*) FROM box_code_unused b2 WHERE b2.box_code_id = box_code.id) AS total2,
    (SELECT COUNT(*) FROM box_code_expired b3 WHERE b3.box_code_id = box_code.id) AS total3
FROM box_code
于 2012-08-21T10:22:47.460 回答
0

我认为您可以使用正确的加入。这样,它将包含一个表中不可用但在另一个表中可用的记录。

于 2012-08-21T10:25:03.060 回答