Нужен SQL-запрос, чтобы найти сообщения с наиболее комментируемым порядком по количеству комментариев / количеству DESC - PullRequest
2 голосов
/ 14 декабря 2011

\ d сообщений

                                   Table "public.posts"
   Column    |          Type          |                     Modifiers                      
-------------+------------------------+----------------------------------------------------
 id          | integer                | not null default nextval('posts_id_seq'::regclass)
 title       | character varying(100) | not null
 content     | character varying(500) | not null
 created_at  | date                   | 
 updated_at  | date                   | 
 tags        | character varying(55)  | not null default '50'::character varying
 category_id | integer                | not null default 1
Indexes:
    "posts_pkey" PRIMARY KEY, btree (id)

\ d комментариев

                                   Table "public.comments"
   Column   |          Type          |                       Modifiers                       
------------+------------------------+-------------------------------------------------------
 id         | integer                | not null default nextval('comments_id_seq'::regclass)
 post_id    | integer                | not null
 name       | character varying(255) | not null
 email      | character varying(255) | not null
 content    | character varying(500) | not null
 created_at | date                   | 
 updated_at | date                   | 
Indexes:
    "comments_pkey" PRIMARY KEY, btree (id)

Мне нужен SQL-запрос для поиска сообщений с наибольшим количеством комментариев.Как я могу это сделать?

Ответы [ 2 ]

4 голосов
/ 14 декабря 2011

в tsql вы бы сделали следующее, я надеюсь, что это направит вас в правильном направлении

SELECT
         p.id,
         c.postcount
    FROM posts as p
    INNER JOIN (
                  SELECT
                         post_id,
                         count(*) AS postcount
                  FROM comments
                  GROUP BY post_id
               ) as c
           on p.id = c.post_id

    Order by c.postcount desc
2 голосов
/ 14 декабря 2011
  SELECT id, title, comment_count
    FROM ( SELECT p.id, p.title, COUNT(c.id) AS comment_count
             FROM posts p
                 ,comments c
             WHERE c.post_id = p.id
             GROUP BY p.id, p.title
             ORDER BY 3 DESC ) x
    LIMIT 1;
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...