Re:Выборка страницы
- From
- Sergiy Medvynskyy (2:5020/175.2)
- To
- Alexander Goldun
- Date
- 2006-06-08T17:02:28Z
- Area
- SU.DBMS.SQL
From: "Sergiy Medvynskyy" <medvynskyy@xtramind.com>
>>> Выяснить номер записи в выборке, например подсчитав count(*) по условию
>>> сортировки выборки, типа такого
>>> SELECT count(tiket_id) FROM tiket WHERE customer_id=? AND
>>> creation_date<? (правда нужно обеспечить однозначность сортировки)
>>> Из полученного номера выяснить страницу и, соответственно номер
>>> начальной записи n - арифметика.
>> Прошу прощения, но я, видимо, не силен в арифметике :).
AG> Допустим искомая запись имеет номер Х. В странице Y записей.
AG> омер
AG> начальной записи в странице:
AG> N := ((X-1) div Y)*Y+1
Ты, наверное, непонял всю задачу. Ключ (значение из колонки ticket_id, которое
я имею) не равен Индексу. Ключ, скажем, 1000, а в выборке он идет на первом
месте, поскольку она состоит из ключей (1000, 1001, 1002 ...).
Еще раз проясню задачу. Предположим, есть выборка по вышеупомянутому запросу:
(5, 10, 15, 25, 30, ...). У меня есть ключ, скажем 555. Необходимо не получая
всю выборку (ну не надо мне все 100К ключей) найти индекс этого ключа в
выборке, при размере страницы 10 записей и выбрать все записи с этой страницы.
В общем все гораздо запущеннее, чем ты предполагал :)
Sergiy Medvynskyy
--- ifmail v.2.15dev5
* Origin: FidoNet Online - http://www.fido-online.com (2:5020/175.2)
SEEN-BY: 50/12 203 450/186 1024 451/30 454/9 4614/20 5000/5000 5001/5001
SEEN-BY: 5010/53 5011/13 5012/23 46 5015/28 5019/31 5020/175 400 545 639 715
SEEN-BY: 5020/758 830 1523 1604 2238 4441 5021/3 29 5022/128 5025/3 750
SEEN-BY: 5026/10 45 5027/12 5029/32 5030/473 556 966 1063 1080 1339 1900
SEEN-BY: 5035/38 5040/47 5042/13 5045/7 5047/47 5054/1 8 9 28 35 37 45 63 67
SEEN-BY: 5055/95 5059/9 5062/1 5077/70 5080/68 1003 5082/6 5083/21 5084/32
SEEN-BY: 5085/13 5090/106 5095/20 5096/18 5099/133
PATH: 5020/175 4441 545 5054/1 37