-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy patharticle-views-i.sql
61 lines (52 loc) · 1.7 KB
/
article-views-i.sql
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
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
/*
Table: Views
+---------------+---------+
| Column Name | Type |
+---------------+---------+
| article_id | int |
| author_id | int |
| viewer_id | int |
| view_date | date |
+---------------+---------+
There is no primary key for this table, it may have duplicate rows.
Each row of this table indicates that some viewer viewed an article (written by some author) on some date.
Note that equal author_id and viewer_id indicate the same person.
Write an SQL query to find all the authors that viewed at least one of their own articles.
Return the result table sorted by id in ascending order.
The query result format is in the following example.
Example 1:
Input:
Views table:
+------------+-----------+-----------+------------+
| article_id | author_id | viewer_id | view_date |
+------------+-----------+-----------+------------+
| 1 | 3 | 5 | 2019-08-01 |
| 1 | 3 | 6 | 2019-08-02 |
| 2 | 7 | 7 | 2019-08-01 |
| 2 | 7 | 6 | 2019-08-02 |
| 4 | 7 | 1 | 2019-07-22 |
| 3 | 4 | 4 | 2019-07-21 |
| 3 | 4 | 4 | 2019-07-21 |
+------------+-----------+-----------+------------+
Output:
+------+
| id |
+------+
| 4 |
| 7 |
+------+
*/
SELECT DISTINCT B.author_id id
FROM
(
SELECT article_id
,SUM(CASE WHEN author_id = viewer_id THEN 1 ELSE 0 END) AS cnt_authors
FROM Views
GROUP BY article_id
HAVING SUM(CASE WHEN author_id = viewer_id THEN 1 ELSE 0 END) <> 0
) A
LEFT JOIN Views B
ON A.article_id = B.article_id
WHERE B.author_id = B.viewer_id
ORDER BY id ASC
;