about summary refs log tree commit diff
path: root/migrations/2018-05-25-161939_add_closed_to_index/up.sql
blob: 87580a2f3f9e0abe7cd3000442519800709f6665 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
-- Update the index view:
DROP VIEW thread_index;
CREATE VIEW thread_index AS
  SELECT t.id AS thread_id,
         t.title AS title,
         ta.name AS thread_author,
         t.posted AS created,
         t.sticky AS sticky,
         t.closed AS closed,
         p.id AS post_id,
         pa.name AS post_author,
         p.posted AS posted
    FROM threads t
    JOIN (SELECT DISTINCT ON (thread_id)
           id, thread_id, user_id, posted
          FROM posts
          ORDER BY thread_id, id DESC) AS p
    ON t.id = p.thread_id
    JOIN users ta ON ta.id = t.user_id
    JOIN users pa ON pa.id = p.user_id
    ORDER BY t.sticky DESC, p.id DESC;

-- Update post view:
DROP VIEW simple_posts;
CREATE VIEW simple_posts AS
  SELECT p.id AS id,
         thread_id, body,
         p.posted AS posted,
         p.user_id AS user_id,
         threads.closed AS closed,
         users.name AS author_name,
         users.email AS author_email
  FROM posts p
  JOIN users ON users.id = p.user_id
  JOIN threads ON threads.id = p.thread_id;