Модераторы: LSD
  

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> Достать предыдущие значения, по отношению к заданному 
V
    Опции темы
Platon
Дата 4.12.2008, 21:12 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
***


Профиль
Группа: Завсегдатай
Сообщений: 1801
Регистрация: 25.4.2006

Репутация: нет
Всего: 40



Здравствуйте, уважаемые.

Трудно сформулировать, чего я хочу. 

есть данные

Цитата

eId  kId   position  scan_time   id
 1     1        1             1           1
 1     2        3             1           2
 2     1        5             1           3
 2     2        5             1           4

 1     1        5             2           5
 1     2        6             2           6
 2     1        7             2           7
 2     2        8             2           8

 1     1        4             3           9
 1     2        5             3           10
 2     1        6             3           11
 2     2        9             3           12


Мне нужно составить список eId, kId, position, id для "предыдущего сеанса (scan_time)" по отношению к заданному для каждого ключа(если так можно выразиться) "eId kId" . Но предыдущего не совсем.
Пример по данным: по отношению к scan_time = 3 список будет следующий
Цитата

eId  kId   position  scan_time   id
 1     1        5             2           5
 1     2        6             2           6
 2     1        7             2           7
 2     2        8             2           8


Если же в таблице данных будет отсутствовать запись с ID = 7, то получится:
Цитата

eId  kId   position  scan_time   id
 1     1        5             2           5
 1     2        6             2           6
 2     1        5             1           3
 2     2        8             2           8


Эквивалентный запрос:
Код

SELECT eId, kId, position FROM ttt AS t1 
WHERE scan_time = (SELECT MAX(scan_time) 
                              FROM ttt AS t2 
                              WHERE t2.scan_time < ? AND t2.eId = t1.eId AND t2.kId = t1.kId
                           )

Но такой запрос только на утилизацию, что я и делаю smile

Прошу о помощи.
PM MAIL ICQ   Вверх
Akella
Дата 5.12.2008, 09:38 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Творец
****


Профиль
Группа: Модератор
Сообщений: 18485
Регистрация: 14.5.2003
Где: Корусант

Репутация: 3
Всего: 329



Код

SELECT eId, kId, position FROM ttt AS t1 
WHERE scan_time = :param1 - 1

задаёшь в параметре значение и тебе будет результат с учётом - 1
или я чего-то недопонял?
PM MAIL   Вверх
Zloxa
Дата 5.12.2008, 09:58 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Чо?
****


Профиль
Группа: Завсегдатай
Сообщений: 3473
Регистрация: 12.9.2008

Репутация: 11
Всего: 161



Целевая платформа?
Почему Ваш запрос "на утилизацию"?


Это сообщение отредактировал(а) Zloxa - 5.12.2008, 10:25


--------------------
Достоверно известно, что 89% людей доверяют статистике взятой с потолка smile
PM   Вверх
Platon
Дата 5.12.2008, 10:32 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
***


Профиль
Группа: Завсегдатай
Сообщений: 1801
Регистрация: 25.4.2006

Репутация: нет
Всего: 40



Zloxa, H2DB


Akella, существуют точки разрыва. Как привел пример 
Цитата(Platon @  4.12.2008,  22:12 Найти цитируемый пост)
Если же в таблице данных будет отсутствовать запись с ID = 7, то получится:


Цитата

eId  kId   position  scan_time   id
 1     1        5             2           5
 1     2        6             2           6
 2     1        5             1           3
 2     2        8             2           8


т.е. грубо говоря для каждого "eId, kId" надо найти запись с предыдущим по отношению к заданной scan_time.

Для каждого eId, kId выполнять такой запрос 
Код

SELECT position FROM ttt 
WHERE eId = :eId AND kId = :kId AND scan_time = 
             (SELECT MAX(scan_time) FROM ttt
              WHERE eId = :eId AND kId = :kId AND scan_time < :reqScanTime
             )

PM MAIL ICQ   Вверх
Zloxa
Дата 5.12.2008, 10:42 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Чо?
****


Профиль
Группа: Завсегдатай
Сообщений: 3473
Регистрация: 12.9.2008

Репутация: 11
Всего: 161



Код

select eId,kid
       ,to_number(substr(max(lpad(scan_time,40,'0')||position),41)) last_position
       ,max(scan_time) last_scan
  from ttt
  where scan_time < 3
group by eId,kid;
 
       EID        KID LAST_POSITION  LAST_SCAN
---------- ---------- ------------- ----------
         1          1             5          2
         1          2             6          2
         2          1             5          1
         2          2             8          2
 
SQL> 

Этот подход в ораклином форуме на sql.ru называют "бабушкиным методом".
Этот метод использовался до появления ранжирующих функций в диалекте оракла.
Cуть метода - составить строку, которая начинается с ранжируемого значения а в хвосте несет информационную стоставлющую, вычислить аггрегат по полученной строке, затем разобрать ее и извлечь информационную стоставлющую.
В нашем примере мы ранжируемся по scan_time. В аггрегируемом выражении мы переводим значение scan_time в строку и дополняем лидирующими нулями до максимальной разрядности числа (в оракле это 40. если у нас scan_time int(10), достаточно будет дополнять до 10 символов) для того, чтобы упорядочивание по строковому представлению совпадало с упорядочиванием по числовому представлению. Хвостиком, мы цепляем к строке position. После вычисления максимального значения из полученной строки извлекаем position.

Данный подход не совсем красив и эстетичен. Но позволяет одним проходом, без джойнов достичь желаемого. И, он весьма универсален. Достаточно лишь перевести строковые функции на диалект целевой платформы.

Это сообщение отредактировал(а) Zloxa - 19.9.2009, 02:56


--------------------
Достоверно известно, что 89% людей доверяют статистике взятой с потолка smile
PM   Вверх
Platon
Дата 5.12.2008, 13:30 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
***


Профиль
Группа: Завсегдатай
Сообщений: 1801
Регистрация: 25.4.2006

Репутация: нет
Всего: 40



Zloxa, оох какая интересная теория! Спасибо попробую.
PM MAIL ICQ   Вверх
Platon
Дата 5.12.2008, 15:48 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
***


Профиль
Группа: Завсегдатай
Сообщений: 1801
Регистрация: 25.4.2006

Репутация: нет
Всего: 40



Оформил. Работает. 
Zloxa, +1!!!
PM MAIL ICQ   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "Общие вопросы по базам данных"
LSD
Zloxa

Данный форум предназначен для обсуждения вопросов о базах данных не попадающих под тематику других форумов:

  • вопросам по СУБД для которых нет отдельных подфорумов
  • вопросам которые затрагивают несколько разных СУБД (например проблема выбора)
  • инструменты для работы с СУБД
  • вопросы проектирования БД
  • теоретически вопросы о СУБД

Данный форум не предназначен для:

  • вопросов о поиске разлиных БД (если не понимаете чем БД отличается от СУБД то: а) вам не сюда; б) Google в помощь)
  • обсуждения проблем с доступом к СУБД из различных ЯП (для этого есть соответсвующие форумы по каждому ЯП)
  • обсуждения проблем с написание SQL запросов, для этого есть форум Составление SQL-запросов
  • просьб о написании курсовой, реферата и т.п., для этого есть Центр помощи или фриланс биржа
  • объявлений о найме специалистов, для этого есть раздел Объявления о найме специалистов

Если вы не соблюдаете эти правила, не удивляйтесь потом не найдя свою тему/сообщение. ;)


Полезные советы:

При написании сообщения постарайтесь дать теме максимально понятное название. В теме максимально подробно опишите проблему. Если применимо укажите: название базы данных и версии (MySQL 4.1, MS SQL Server 2000 и т.п.); используемых язык программирования; способа доступа (ADO, BDE и т.д.); сообщения об ошибках.

Для вставки кода используйте теги [code=sql] [/code].

Литературу по базам данных можно поискать здесь.

Действия модераторов можно обсудить здесь.


Если Вам понравилась атмосфера форума, заходите к нам чаще! С уважением, LSD, Zloxa.

 
1 Пользователей читают эту тему (1 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | СУБД, общие вопросы | Следующая тема »


 




[ Время генерации скрипта: 0.0883 ]   [ Использовано запросов: 21 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.