|
select c последней датой
|
|||
---|---|---|---|
#18+
Уважаемые гуру, зациклился на select Из следующего курсора нужно выбрать записи с max(последней) датой DatInit . ------------------------------------- |ID|DatInit|Km|Idjour| kizg| naimnd|... ------------------------------------ |01|01.01.10|111|11|1|ГОСТ|.... |02|01.01.09|111|11|1|ГОСТ|.... |03|15.01.09|111|11|1|ГОСТ|.... |04|01.01.10|222|22|2|ТУ|.... |05|02.02.09|222|22|2|ТУ|.... |06|01.01.10|33|30|1|ГОСТ|.... |07|01.01.10|111|29|1|ГОСТ|.... Primary Key=ID Unique Key= DatInit+Km+Idjour+ kizg+ naimnd... В результирующем курсоре должны попасть записи с ID=01, 04, 06, 07 т.е. с максимальной датой внутри ключа DatInit+Km+Idjour+ kizg+ naimnd Спасибо большое за любые слова ... |
|||
:
Нравится:
Не нравится:
|
|||
05.05.2010, 17:39 |
|
select c последней датой
|
|||
---|---|---|---|
#18+
Код: plaintext
... |
|||
:
Нравится:
Не нравится:
|
|||
05.05.2010, 18:54 |
|
select c последней датой
|
|||
---|---|---|---|
#18+
A432, спасибо, НО....... Если б все было так просто :-) Данный запрос вернет записи или запись с последней датой для всей таблицы, а нужно чтобы запрос вернул по каждому индексу (ключу) запись с последней датой, что-то вроде типа этого (пример не совсем корректен т.к. он возвращает записи с одинаковым ключом KM+KIZG+NAIMND , но разными датами): SELECT tb1.* FROM tb1, tb2 ; WHERE tb1.ID_Jour = tb2.ID_Jour ; .AND. tb1.KM = tb2.KM ; .AND. tb1.KIZG = tb2.KIZG ; .AND. tb1.NAIMND = tb2.NAIMND ; .AND. tb1.DatInit <> tb2.DatInit ; INTO CURSOR asd READWRITE ... |
|||
:
Нравится:
Не нравится:
|
|||
06.05.2010, 08:30 |
|
select c последней датой
|
|||
---|---|---|---|
#18+
select <Поле1>, <Поле2>, ......., <Поле-n>, max(дата) from твоя_таблица group by <Поле1>, <Поле2>, ......., <Поле-n> ... |
|||
:
Нравится:
Не нравится:
|
|||
06.05.2010, 09:02 |
|
select c последней датой
|
|||
---|---|---|---|
#18+
AkIgУважаемые гуру, зациклился на select Из следующего курсора нужно выбрать записи с max(последней) датой DatInit . ------------------------------------- |ID|DatInit|Km|Idjour| kizg| naimnd|... ------------------------------------ |01|01.01.10|111|11|1|ГОСТ|.... |02|01.01.09|111|11|1|ГОСТ|.... |03|15.01.09|111|11|1|ГОСТ|.... |04|01.01.10|222|22|2|ТУ|.... |05|02.02.09|222|22|2|ТУ|.... |06|01.01.10|33|30|1|ГОСТ|.... |07|01.01.10|111|29|1|ГОСТ|.... Primary Key=ID Unique Key= DatInit+Km+Idjour+ kizg+ naimnd... В результирующем курсоре должны попасть записи с ID=01, 04, 06, 07 т.е. с максимальной датой внутри ключа DatInit+Km+Idjour+ kizg+ naimnd Спасибо большое за любые слова Это несложно решить с помошью корреляционного подзапроса: Код: plaintext 1. 2. 3. 4. 5. 6. 7. 8. 9. 10. 11.
... |
|||
:
Нравится:
Не нравится:
|
|||
06.05.2010, 09:41 |
|
select c последней датой
|
|||
---|---|---|---|
#18+
Aleksey-K, Спасибо большое. То что нужно. ... |
|||
:
Нравится:
Не нравится:
|
|||
06.05.2010, 10:05 |
|
select c последней датой
|
|||
---|---|---|---|
#18+
AkIg, А сгруппировать данные по ключу и выбрать интересующее в группе? SQL с кучей INSERT - хм, вы себя не жалеете совсем... A432 правильно ответил. Только я бы еще добавил что-то вроде: SELECT ID, MAX(DatInit) AS DatInit, Km, Idjour, kizg, naimnd FROM ТвойТейбл ; GROUP BY DatInit, Km, Idjour, kizg, naimnd ... |
|||
:
Нравится:
Не нравится:
|
|||
06.05.2010, 15:28 |
|
|
start [/forum/search_topic.php?author=profile32&author_mode=last_topics&do_search=1]: |
0ms |
get settings: |
10ms |
get forum list: |
14ms |
get settings: |
10ms |
get forum list: |
14ms |
check forum access: |
4ms |
check topic access: |
4ms |
track hit: |
30ms |
get topic data: |
9ms |
get forum data: |
2ms |
get page messages: |
41ms |
get tp. blocked users: |
1ms |
others: | 787ms |
total: | 926ms |
0 / 0 |