Why You Shouldn’t Use OFFSET and LIMIT For Your Pagination
Why You Shouldn’t Use OFFSET and LIMIT For Your Pagination
LIMIT and OFFSET have been misused for years for building Paginations for APIs. Learn here How To Improve Your Pagination Performance.
If you are wondering why lemmy is moving away from offset pagination since 0.19, here is a nice article about it
You're viewing a single thread.
Paywall.
15 0 Replyhttps://ivopereira.net/efficient-pagination-dont-use-offset-limit
This seems to be the same article.
I have my doubts about the technique, but it could be useful in certain controlled situations.
10 0 ReplyLemmy just implemented it for 0.19 and it makes a big difference on heavier queries like Scaled homepage.
It also has the advantage of your pagination not getting screwy if new content has been added between page 2 and 3 queries.
6 0 ReplyI was going to recommend looking at https://www.elastic.co/guide/en/elasticsearch/reference/current/paginate-search-results.html#scroll-search-results - but it looks like that method is now not advised- but if you read up above it it looks like there’s a search_after/PIT method described which sounds similar to the article.
This is all to say - I don’t think this is a one-off concept - it’s been around for a bit.
3 0 ReplyIt depends on what you want to do and how you want it to behave if data is inserted or deleted. “Ten items after the last one I’ve seen” is another thing than “items 30 to 39”.
1 0 Reply
Thanks! Agreed, it's a very limited usecase.
1 0 ReplyI have my doubts about the technique, but it could be useful in certain controlled situations
This is completely uncontroversial advice and has been for 30 years. What are your doubts exactly?
I’d go further: if you see a query that uses “offset” on a non-trivial production DB something is very, very wrong.
Of course, the trick is that you need to make sure you have indexes for all sort orders you need to display, but that’s obvious.
1 0 Reply
Sorry, I updated the link
2 1 Reply