Привет! Почему offset не может взять данные прямо из неотсортированного

результата выборки?

Почему он вынужден идти по всей таблице, когда результат выборки не отсортирован?

Все ответы, которые я слышу: "это потому что данные не отсортированы", но это не ответ на мой вопрос..

Буду крайне благодарен, если поможете. Сижу на этим уже со вчерашнего дня

11 ответов

71 просмотр

Хочешь получить на выходе говно?

убери offset, оставь limit -эффект будет такой же.

А4 Одноногое- Автор вопроса
Ilya Zviagin
Хочешь получить на выходе говно?

Нет, я хочу понять, почему когда результат выборки не отсортирован, offset вынужден идти по всей таблице, вместо того, чтобы сразу взять данные из результата выборки

Он не вынужден. Ты лучше пришли описание таблиц (DDL) и запрос, и тогда можно обсудить.

А4 Одноногое- Автор вопроса
Ilya Zviagin
Он не вынужден. Ты лучше пришли описание таблиц (...

Мне везде говорят (вот абсолютно везде), что offset будет считывать всю таблицу, если результат выборки не отсортирован

А4 Одноногое
Мне везде говорят (вот абсолютно везде), что offse...

Однозначно без запроса это сказать нельзя. Да и с запросом тоже, план составляет СУБД, и она может делать это как угодно. Я бы на месте производителя СУБД OFFSET без ORDER BY просто игнорировал бы

А4 Одноногое
Мне везде говорят (вот абсолютно везде), что offse...

зачем тебе вообще OFFSET - это же идиотская конструкция ...

А4 Одноногое- Автор вопроса
А4 Одноногое
Для пагинации. Есть альтернативы?

Пагинацию вообще не надо делать, надо её выбрасывать.

Не по всей, а только offset+limit. Но если limit не указан, тогда что есть offset (получаем строки с n позиции), что нет (получаем все строки). Особой разницы не будет(в случае, если не используется ключ). Это всего лишь маркер с какой строки начинать отдачу данных. И именно с этим и связана концепция, что если запрос возвращает более 500 записей (у каждого это своя граница), значит пользователь делает что то не так. Такое допустимо только в процессах, где пользователь не участвует (импорты/экспорту/конвертации/автоматические обработки данных), но там и offset как раз таки обычно не нужен, там как раз используют last row id of previous query + limit. Более того, сортировка вообще не влияет на скорость offset. Если сделать селект по обычной таблице без условий where, то очевидно, что будут браться строки по первичному ключу, который отсортирован. И вот именно по таблице ключей и можно применить offset и limit и по выбранным ключам уже строить результат. Если запрос сложный, то там у итогового результата может и не быть конечного ключа или сортировка не по ключевому полю, и тогда тут offset применится к результату выборки. Но опять же повторюсь. Результат может давать и 10 строк и 1000000 строк и скорость будет падать при отборе, а не применении offset.

Похожие вопросы

Обсуждают сегодня

Добрый вечер, Пока не совсем понимаю как наладить общение между телеграм ботом и ПО для работы с сим боксом. По самому боту так понял: - Нужен некий баланс, который можно поп...
Magic
6
сделал сайт, прикрутил в боте сайт, и виджет логина. как автоматически логинить пользователя в аккаунт(телеграм), при входе с бота?
Александра Чернивецкая
5
Объясните, пожалуйста, почему компилятор ругается на использование в условии неинициализированной переменной: int x; Task.Run(async () => { x = await somefunc(); }).Wait...
Александр
5
Ребят, подскажите, пожалуйста, почему в префиксе к ассетам, которые генерируются через фильтр | theme в шаблоне, стал вдруг появляться index.php? Вот так выглядит ссылка на а...
Виталий
1
Всем привет. Ребята, подскажите, пожалуйста. у ботов есть ограничение на отправку сообщений - 30 сообщений в секунду, эти ограничения накладываются на все сообщения? или на со...
Artem Stormageddon
4
Блин, ребята, сори за тупые вопросы. А можно ли как-то открыть вебапку по нажатию на кнопку в меню(которое появляется слева, команды)?
Artem Stormageddon
3
а плаксы из-под питона умеют только в комфортных условиях что-то выдавить из себя?)
Lencore
9
Но, может, есть уже проверенная? Наши требования такие: 1. Сообщения должны приходить из Инста в CRM оду 2. Должна быть возможность подключить несколько экаунтов Инстаграм. Р...
Alexander Sharoiko MSE / Александр Шаройко
13
Это может быть все-таки не флудвейт? у меня ботфазер принимает изменения и отображает даже что они изменились, на видео видно что он прислал якобы уже измененное описание, н...
OVERLINK
13
Коллеги, может знает кто, можно ли цвет бейджа счётчика в BackendMenu менять без бубнов?
Alex Blaze
3
Карта сайта