aboutsummaryrefslogtreecommitdiffhomepage
path: root/backend/db/queries
diff options
context:
space:
mode:
Diffstat (limited to 'backend/db/queries')
-rw-r--r--backend/db/queries/articles.sql40
1 files changed, 26 insertions, 14 deletions
diff --git a/backend/db/queries/articles.sql b/backend/db/queries/articles.sql
index 5acdada..bd4cd91 100644
--- a/backend/db/queries/articles.sql
+++ b/backend/db/queries/articles.sql
@@ -7,23 +7,35 @@ INNER JOIN feeds AS f ON a.feed_id = f.id
WHERE a.id = ?;
-- name: GetUnreadArticles :many
-SELECT
- a.id, a.feed_id, a.guid, a.title, a.url, a.is_read,
- f.id as feed_id_2, f.url as feed_url, f.title as feed_title, f.is_subscribed as feed_is_subscribed
-FROM articles AS a
-INNER JOIN feeds AS f ON a.feed_id = f.id
-WHERE a.is_read = 0 AND f.is_subscribed = 1 AND f.user_id = ?
-ORDER BY a.id DESC
+WITH ranked AS (
+ SELECT
+ a.id, a.feed_id, a.guid, a.title, a.url, a.is_read,
+ f.id as feed_id_2, f.url as feed_url, f.title as feed_title, f.is_subscribed as feed_is_subscribed,
+ ROW_NUMBER() OVER (PARTITION BY a.guid ORDER BY a.id) as rn
+ FROM articles AS a
+ INNER JOIN feeds AS f ON a.feed_id = f.id
+ WHERE a.is_read = 0 AND f.is_subscribed = 1 AND f.user_id = ?
+)
+SELECT id, feed_id, guid, title, url, is_read, feed_id_2, feed_url, feed_title, feed_is_subscribed
+FROM ranked
+WHERE rn = 1
+ORDER BY id DESC
LIMIT 100;
-- name: GetReadArticles :many
-SELECT
- a.id, a.feed_id, a.guid, a.title, a.url, a.is_read,
- f.id as feed_id_2, f.url as feed_url, f.title as feed_title, f.is_subscribed as feed_is_subscribed
-FROM articles AS a
-INNER JOIN feeds AS f ON a.feed_id = f.id
-WHERE a.is_read = 1 AND f.is_subscribed = 1 AND f.user_id = ?
-ORDER BY a.id DESC
+WITH ranked AS (
+ SELECT
+ a.id, a.feed_id, a.guid, a.title, a.url, a.is_read,
+ f.id as feed_id_2, f.url as feed_url, f.title as feed_title, f.is_subscribed as feed_is_subscribed,
+ ROW_NUMBER() OVER (PARTITION BY a.guid ORDER BY a.id) as rn
+ FROM articles AS a
+ INNER JOIN feeds AS f ON a.feed_id = f.id
+ WHERE a.is_read = 1 AND f.is_subscribed = 1 AND f.user_id = ?
+)
+SELECT id, feed_id, guid, title, url, is_read, feed_id_2, feed_url, feed_title, feed_is_subscribed
+FROM ranked
+WHERE rn = 1
+ORDER BY id DESC
LIMIT 100;
-- name: GetArticlesByFeed :many