有效地组合两个SQL查询

时间:2015-03-22 23:17:12

标签: mysql performance

我有两个查询:

1)

SELECT COUNT(*) AS total, COUNT(supporter) AS done FROM Supports;

2)

SELECT supporter, COUNT(supporter) AS amount FROM Supports 
GROUP BY supporter ORDER BY amount DESC LIMIT 1;

如何有效地将它们组合起来?

这就是表格的样子:

+-----------------------------+
| id    | name    | supporter |
+-----------------------------+
|    1  | user1   |    sup1   |
|    2  | user1   |    sup2   |
|    3  | user1   |    NULL   |
|    4  | user2   |    sup1   |
|    5  | user2   |    sup3   |
+-----------------------------+

3 个答案:

答案 0 :(得分:1)

由于您需要总计,因此您必须使用子查询合并为一个查询。将其包含在FROM子句中。

SELECT supporter, COUNT(supporter) AS amount, total, done 
FROM Supports,
    (SELECT COUNT(*) AS total, COUNT(supporter) AS done FROM Supports) totals
GROUP BY supporter
ORDER BY amount DESC
LIMIT 1;

答案 1 :(得分:1)

我相信这就是你要找的东西:

SELECT
  (SELECT COUNT(*) FROM Supports) as total,
  (SELECT COUNT(supporter) FROM Supports) as done,
  supporter, 
  COUNT(*) AS amount 
FROM Supports 
GROUP BY supporter 
ORDER BY amount;

结果如下所示:http://sqlfiddle.com/#!9/9e4ee/9

total  done  supporter   amount
5      4     sup3        1
5      4     sup2        1
5      4     NULL        1
5      4     sup1        2

答案 2 :(得分:0)

SELECT  a.total, a.done, b.supporter, b.amount 
      ( SELECT  COUNT(*) AS total, 
                COUNT(supporter) AS done
            FROM  Supports 
      ) AS a
    JOIN  
      ( SELECT  supporter, 
                COUNT(supporter) AS amount
            FROM  Supports
            GROUP BY  supporter
            ORDER BY  amount DESC
            LIMIT  1 
      ) AS b;