Форум по Delphi программированию

Delphi Sources



Вернуться   Форум по Delphi программированию > Все о Delphi > [ "Начинающим" ]
Ник
Пароль
Регистрация <<         Правила форума         >> FAQ Пользователи Календарь Поиск Сообщения за сегодня Все разделы прочитаны

Ответ
 
Опции темы Поиск в этой теме Опции просмотра
  #1  
Старый 17.09.2016, 22:23
aqula aqula вне форума
Новичок
 
Регистрация: 19.10.2012
Сообщения: 95
Репутация: 10
По умолчанию Как DBGrid сделать пагинацию?

Подскажите, как задать максимум отображающихся записей в DBGrid?
Хочу сделать пагинацию с DBGrid.
Думаю может как-то отрисовывать диапазон определенных RecNo.
Ответить с цитированием
  #2  
Старый 17.09.2016, 23:11
lmikle lmikle вне форума
Модератор
 
Регистрация: 17.04.2008
Сообщения: 8,057
Версия Delphi: 7, XE3, 10.2
Репутация: 49089
По умолчанию

Если уж так хочется, то делай в OnFilterRecord в источнике данных. DBGrid прото отображатель данных, на его уровне такое не делается.
А вообще, более правильно делать пейджинг с помощью запроса. Например, Oracle автоматически присваивает каждой записи в выборке RecNo. Соответсвенно, гарантировав порядок сортировки, можно сделать пейджинг с помощью простого were:
Код:
select * from MyTable
where recNo >= (:PageNo-1)*:PageLen and recNo < :PageNo*:PageLen
ЗЫ. Границы лучше рассчитывать на клиенте, в SQL я просто для лучшего понимания написал.
Ответить с цитированием
  #3  
Старый 19.09.2016, 20:39
aqula aqula вне форума
Новичок
 
Регистрация: 19.10.2012
Сообщения: 95
Репутация: 10
По умолчанию

А как подобный запрос в MS SQL 2005 составить?
Или надо как то количество следующих n записей в адошке отфильтровывать?
Ответить с цитированием
  #4  
Старый 19.09.2016, 22:48
lmikle lmikle вне форума
Модератор
 
Регистрация: 17.04.2008
Сообщения: 8,057
Версия Delphi: 7, XE3, 10.2
Репутация: 49089
По умолчанию

В интернете советуют что-то такое:
Код:
SELECT *, ROW_NUMBER() OVER (ORDER BY [column name]) as rowNum
FROM [table name]
order by ROW_NUMBER() OVER (ORDER BY [column name])
Надо только посмотреть с какой версии сервера там оконные функции появились.

ЗЫ. Естестенно, надо запрос доделать под твою ситуацию...
Ответить с цитированием
Ответ


Delphi Sources

Опции темы Поиск в этой теме
Поиск в этой теме:

Расширенный поиск
Опции просмотра

Ваши права в разделе
Вы не можете создавать темы
Вы не можете отвечать на сообщения
Вы не можете прикреплять файлы
Вы не можете редактировать сообщения

BB-коды Вкл.
Смайлы Вкл.
[IMG] код Вкл.
HTML код Выкл.
Быстрый переход


Часовой пояс GMT +3, время: 08:42.


 

Сайт

Форум

FAQ

RSS лента

Прочее

 

Copyright © Форум "Delphi Sources" by BrokenByte Software, 2004-2023

ВКонтакте   Facebook   Twitter