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