Гость
Map
Форумы / Informix [игнор отключен] [закрыт для гостей] / Запрос: получение строки сверху и снизу от указанной / 4 сообщений из 4, страница 1 из 1
26.09.2011, 11:07
    #37455559
Debusen
Гость
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Запрос: получение строки сверху и снизу от указанной
Есть таблица, скажем такая

form section
1 1
1 2
1 4
1 3
2 3
2 4
2 2
2 1

Нужно получить эту таблицу, отсортированную по полям form и section и выбрать из нее три строки - сверху и снизу от указанной и указанную. Для строки с form = 2 и section = 3 это, например будут строки

form section
2 2 - строка сверху
2 3 - переданная в запрос строка
2 4 - строка снизу

Можно ли это сделать средствами SQL? Или нужно перебирать всю таблицу? Не хотелось бы перебирать, таблица достаточно большая.
...
Рейтинг: 0 / 0
26.09.2011, 12:33
    #37455757
АнатоЛой
Участник
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Запрос: получение строки сверху и снизу от указанной
На последних 11.50 прокатило бы такое:

Код: plaintext
1.
2.
3.
4.
5.
6.
7.
8.
9.
10.
11.
12.
13.
14.
15.
16.
17.
18.
SELECT FIRST  2  form, section
  FROM tbl
    WHERE form >=  2  and section >=  3 
ORDER BY form, section
INTO TEMP tmp_tbl1 WITH NO LOG;

SELECT FIRST  2  form, section
  FROM tbl
    WHERE form <=  2  and section <=  3 
ORDER BY form DESC, section DESC
INTO TEMP tmp_tbl2 WITH NO LOG;

SELECT form, section
FROM tmp_tbl1
UNION
SELECT form, section
FROM tmp_tbl2
ORDER BY form, section;

Или тебе одним оператором? И без SPL? И чтоб всё равно быстро и эффективно?
...
Рейтинг: 0 / 0
26.09.2011, 12:42
    #37455788
Debusen
Гость
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Запрос: получение строки сверху и снизу от указанной
Я получаю доступ к Informix через PHP. Как там в один оператор впихнуть три запроса не знаю.
Поэтому лучше конечно бы одним запросом...
Видимо придется все-таки перебирать всю таблицу. :(
...
Рейтинг: 0 / 0
26.09.2011, 16:02
    #37455981
АнатоЛой
Участник
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Запрос: получение строки сверху и снизу от указанной
DebusenЯ получаю доступ к Informix через PHP. Как там в один оператор впихнуть три запроса не знаю.
Поэтому лучше конечно бы одним запросом...
Видимо придется все-таки перебирать всю таблицу. :(
Можно создать хранимую процедуру, которая одним запросом от клиента вернёт вам эту табличку...
...
Рейтинг: 0 / 0
Форумы / Informix [игнор отключен] [закрыт для гостей] / Запрос: получение строки сверху и снизу от указанной / 4 сообщений из 4, страница 1 из 1
Целевая тема:
Создать новую тему:
Автор:
Найденые пользователи ...
Разблокировать пользователей ...
Читали форум (0):
Пользователи онлайн (0):
x
x
Закрыть


Просмотр
0 / 0
Close
Debug Console [Select Text]