Прочетохте ли заглавието на тази статия?
Имайте предвид, че следната статия се отнася само за версии на PostgreSQL преди 9.2. Сега са въведени сканирания само за индекси.
Използвайте 9.2 и като цяло ще откриете, че получавате много по-добри резултати. Прочетете уики страницата за сканиране само за индекс за подробности.
Въпреки това в по-стари версии се използва LIMIT
и OFFSET
като цяло работи добре. Можете да оцените броя на редовете (и следователно броя на страниците), като използвате статистиката на таблицата, ако нямате нищо против малко вариации. Вижте „Оценяване на броя на редовете“ в статията, към която вече сте направили връзка.
Страниране чрез LIMIT
и OFFSET
е, IMO, все пак анти-модел. Много често можете да префразирате кода си за пагинация, така че да използва sort_column > 'last_seen_value' LIMIT 100
, тоест избягва изместването. Това понякога може да доведе до много големи печалби в производителността.