-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathqueries.py
52 lines (38 loc) · 1.91 KB
/
queries.py
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
import datetime
def get_articles_by_group(cur, group_name: str, from_time: str, to_time: str):
"""
Получаем список популярных статей/репозиториев за неделю;
"""
cur.execute("SELECT articles.title, articles.creation_date FROM articles "
"RIGHT JOIN article_group a ON articles.id = a.article_id "
"RIGHT JOIN groups g ON a.group_id = g.id "
"WHERE group_name = '{}' AND creation_date BETWEEN '{}' AND '{}'"
.format(group_name, from_time, to_time))
return cur.fetchall()
def get_top_groups(cur):
"""
Получаем топ 10 популярных хэш-тэгов, т.е. те, у которых больше всего статей/репозиториев;
"""
cur.execute("SELECT group_name, COUNT(article_id) AS article_count FROM articles "
"RIGHT JOIN article_group a ON articles.id = a.article_id "
"RIGHT JOIN groups g ON a.group_id = g.id "
"GROUP BY group_name "
"ORDER BY article_count DESC LIMIT 10")
return cur.fetchall()
def get_top_users(cur):
"""
Получаем список самых активных пользователей, те, у которых больше всего статей
"""
cur.execute("SELECT author_name, article_count FROM authors "
"ORDER BY article_count DESC LIMIT 10")
return cur.fetchall()
def get_articles_by_week(cur):
"""
Получаем список популярных статей/репозиториев за неделю
"""
current_date = datetime.datetime.today()
week_ago = current_date.replace(day=current_date.day - 7)
cur.execute("SELECT title FROM articles "
"WHERE creation_date BETWEEN '{}' AND '{}'"
.format(week_ago, current_date))
return cur.fetchall()