Форум программистов, компьютерный форум, киберфорум
PostgreSQL
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.60/5: Рейтинг темы: голосов - 5, средняя оценка - 4.60
0 / 0 / 0
Регистрация: 18.09.2017
Сообщений: 46

Limit Offset

21.12.2017, 15:09. Показов 977. Ответов 1
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Всем привет, у меня ест функция которая получает 3 параметра и формирует запрос, два параметра для лимит и оффсет, чтобы строки выводились пагинацией.
А как можно обойтись без Limit и Offset!? Я не знаю другого способа и мне кажется если он есть то он все разворотит тут.
Если нужно могу скинут скрипт создания таблицы и ее заполнения случайными данными

Oracle 11 SQL
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
CREATE OR REPLACE FUNCTION spinningline.pagination(INOUT refcur refcursor,elmcount INTEGER DEFAULT NULL::INTEGER, pagenum INTEGER DEFAULT NULL::INTEGER,category INTEGER DEFAULT NULL::INTEGER)
 RETURNS refcursor
 LANGUAGE plpgsql
AS $function$
DECLARE
  l_sql text:= '';
BEGIN
l_sql := 'select row_number() over()-'||elmcount*(pagenum-1)||', product_id,product_name, product_amount 
from spinningline.products
where category_id='||category||'
limit '||elmcount||' offset '||elmcount*(pagenum-1)||';';
    RAISE notice '%', l_sql;
END;
$function$;
 
 
DECLARE qwe CURSOR FOR SELECT * FROM
spinningline.pagination(refcur =>'qwe', elmcount =>15, pagenum =>2, category=>45);
 
FETCH ALL IN qwe;
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
21.12.2017, 15:09
Ответы с готовыми решениями:

ERROR: stack depth limit exceeded
всем привет! Создал тригер для инсерта и в результате вставки выдает ошибку ERROR: stack depth limit exceeded Подсказка: Increase the...

Как в postgres запросе сделать динамический limit?
Добрый день, Не отрабатывается следующий запрос: UPDATE m_hotels set firm_id = 2 where id in (select id from m_hotels order by...

Postresql зависает при выполнении запроса с order и limit
Есть такой запрос select * from log where id = 4123423338 order by time limit 1; он зависает и не выполняется. Такие запросы ...

1
1264 / 978 / 384
Регистрация: 02.09.2012
Сообщений: 3,024
23.12.2017, 02:14
Что-то непонятно, что у вас вернет pagination. Точнее понятно, что она вернет refcursor, но до заполнения его l_sql-ем дело так и не доходит.
Ну да ни в этом суть. Если не хотите, не удобно по каким-то причинам, использовать limit+offset, можно завести доп. таблицу, в которой заранее рассчитывать номера страниц и выдавать их на гора пользователю. Если products не часто меняется - это не внесет серьезных замедлений, но естественно добавить больше кода
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
23.12.2017, 02:14
Помогаю со студенческими работами здесь

Limit
Есть ли в Accesse что-нибудь подобное Limit из mySQL?

Чем можно в Access2000 заменить Limit в запросе?
Всем доброго времени суток. У меня такой вопрос - как можно (если можно) в Access 2000 сделать запрос на n-е число записей? В MySQL я...

Infinite scroll - limit,offset
Добрый день ув. пользователи! Есть функция, которая всегда вызывается при загрузки стр., обращается к базе и выводит данные из таблицы. У...

Limit и Offset: вывод более 50 результатов
Задумка: вывести ссылки на все изображения из блога. Сложность: у АПИ стоит лимит на 50 результатов за 1 вызов. Что делал: играл с...

Выборка со смещением (offset) и ограничением (limit)
Всем привет. Мне нужно выбрать данные из таблицы со смещением и ограничением по количеству записей. Я знаю, что это делается через...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Новые блоги и статьи
[Owen Logic] Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора
ФедосеевПавел 14.03.2026
Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора ВВЕДЕНИЕ Выполняя задание на управление насосной группой заполнения резервуара,. . .
делаю науч статью по влиянию грибов на сукцессию
anaschu 13.03.2026
прикрепляю статью
SDL3 для Desktop (MinGW): Создаём пустое окно с нуля для 2D-графики на SDL3, Си и C++
8Observer8 10.03.2026
Содержание блога Финальные проекты на Си и на C++: hello-sdl3-c. zip hello-sdl3-cpp. zip Результат:
Установка CMake и MinGW 13.1 для сборки С и C++ приложений из консоли и из Qt Creator в EXE
8Observer8 10.03.2026
Содержание блога MinGW - это коллекция инструментов для сборки приложений в EXE. CMake - это система сборки приложений. Здесь описаны базовые шаги для старта программирования с помощью CMake и. . .
Как дизайн сайта влияет на конверсию: 7 решений, которые реально повышают заявки
Neotwalker 08.03.2026
Многие до сих пор воспринимают дизайн сайта как “красивую оболочку”. На практике всё иначе: дизайн напрямую влияет на то, оставит человек заявку или уйдёт через несколько секунд. Даже если у вас. . .
Модульная разработка через nuget packages
DevAlt 07.03.2026
Сложившийся в . Net-среде способ разработки чаще всего предполагает монорепозиторий в котором находятся все исходники. При создании нового решения, мы просто добавляем нужные проекты и имеем. . .
Модульный подход на примере F#
DevAlt 06.03.2026
В блоге дяди Боба наткнулся на такое определение: В этой книге («Подход, основанный на вариантах использования») Ивар утверждает, что архитектура программного обеспечения — это структуры,. . .
Управление камерой с помощью скрипта OrbitControls.js на Three.js: Вращение, зум и панорамирование
8Observer8 05.03.2026
Содержание блога Финальная демка в браузере работает на Desktop и мобильных браузерах. Итоговый код: orbit-controls-threejs-js. zip. Сканируйте QR-код на мобильном. Вращайте камеру одним пальцем,. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru