1

私の質問は、私が解決策を試したthis one に似ていますが、私のシナリオには正確ではありませんでした。

投票と投稿の 2 つのテーブルがあります。基本的なスケッチは次のとおりです。

`posts`
----+------------------------------------------------------------------------+
| ID | post_title                                                            |
+----+-----------------------------------------------------------------------+
|  1 | Hello world.                                                          |
|  2 | This is a post!                                                       |
|  3 | What is the meaning of life?                                          |
|  4 | Looking for a good time?                                              |
+----+-----------------------------------------------------------------------

`votes`
+----+---------+
| ID | post_id | 
+----+---------+
|  1 |     1   |  
|  2 |     1   | 
|  3 |     1   |  
|  4 |     3   | 
|  5 |     3   |  
|  6 |     4   |  
+----+---------+

問題:

各投稿の得票数を知りたいので、得票数の多い投稿が上位になるように表示します。

     Post ID   Vote Count
   +---------+-----------+
   | 1       | 3         |
   | 3       | 2         |
   | 4       | 1         |
   | 2       | 0         |

この目標を達成するための SQL クエリはどのようなものですか?

4

3 に答える 3

5
select post_id, count(*)
from votes
group by post_id
order by count(*) desc

編集:

select v.post_id, count(*)
from votes v INNER JOIN posts p ON v.post_id = p.id
group by v.post_id
order by count(*) desc
于 2011-11-02T14:52:17.013 に答える
3
SELECT post_id, COUNT(*) AS tally
  FROM votes
 GROUP 
    BY post_id
UNION
SELECT ID AS post_id, 0 AS tally
  FROM posts
 WHERE ID NOT IN (SELECT post_id FROM votes);
于 2011-11-02T15:56:21.763 に答える
0

UINONを実行せずに投票数がゼロの投稿を含めたい場合は、次のことができます

  SELECT 
         p.id, 
         SUM(CASE WHEN v.post_id IS NOT NULL THEN 1 ELSE 0 END)  AS tally
  FROM  
      posts p
      LEFT JOIN votes v
      ON v.post_id = p.id
  ORDER BY  
      SUM(CASE WHEN v.postid IS NOT NULL THEN 1 ELSE 0 END) DESC
  GROUP 
    BY p.id

COUNT(NULL) = 1 であるため、ここでは SUM/CASE が必要です。

あなたの構造は非常に近いので、data.SEで見ることができる例を次に示します

于 2011-11-02T17:09:07.223 に答える