sql - 添加 LEFT JOIN 后损坏的计数 (*)

标签 sql mysql count left-join

自从将 LEFT JOIN 添加到下面的查询中后,count(*) 一直在返回一些奇怪的值,它似乎已将查询中返回的总行数添加到“级别”:

SELECT `n`.*, exp_channel_titles.*, round((`n`.`rgt` - `n`.`lft` - 1) / 2, 0) AS childs,  
count(*) - 1 + (`n`.`lft` > 1) + 1 AS level,  
((min(`p`.`rgt`) - `n`.`rgt` - (`n`.`lft` > 1)) / 2) > 0 AS lower,  
(((`n`.`lft` - max(`p`.`lft`) > 1))) AS upper  
FROM `exp_node_tree_6` `n` 
    LEFT JOIN `exp_channel_titles` 
    ON (`n`.`entry_id`=`exp_channel_titles`.`entry_id`), 
    `exp_node_tree_6` `p`,  
    `exp_node_tree_6`  
WHERE `n`.`lft`  
BETWEEN `p`.`lft`  
AND `p`.`rgt`  
AND ( `p`.`node_id` != `n`.`node_id` OR `n`.`lft` = 1 ) 
GROUP BY `n`.`node_id`  
ORDER BY `n`.`lft`

我完全被难住了...谢谢!

最佳答案

如果您想知道计数,只需在没有group by 的情况下运行查询。您会看到计数中的行来自何处​​。

在您的情况下,您可能可以通过将 count(*) 更改为 count distinct(n.entry_id) 来修复它。

关于sql - 添加 LEFT JOIN 后损坏的计数 (*),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/2574918/

相关文章:

php - 在MYSQL中,我想获得具有多个条件的多个SUM来进行总计并获得价格里程碑

java - 计算java中存档中的文件数

sql - 如何将这两个 SELECT 语句合并为一个

mysql - 如何在 Sequel Pro 中执行查询?

SQL 查询顺序错误,不知道为什么

sql - GAE 数据存储大量数据

sql-server - 计算行数而不发出单独的计数

python - 从现有词典创建频率词典

sql - 条件连接不同的表

sql - 可以将Elasticsearch用于星型模式吗?