Re: Запрос

From
Alexey Gradovtsev (2:5020/400)
To
Alex Cherednichenko (2:5054/37.63)
Date
2005-05-12T16:35:30Z
Area
SU.DBMS.SQL
From: "Alexey Gradovtsev" <agradov@main.sdg.neva.ru>

Thu May 12 2005 14:46, Alex Cherednichenko wrote to Alexey Gradovtsev:

 AG>> Задача - выбрать из таблицы поле, соответствующее последней дате.
 AG>> Интересует не только возможность выборки, но и возможность использования
 AG>> в апдейте.

 AC> Многое зависит от того, какой сервер ты используешь.
 AC> Для большинства серверов, поддерживающих стандарт SQL-92,
 AC> для insert прокатит такая конструкция:

 AC> insert into table1(field1, field2, ...)
 AC> select field1, field2, ... from table2
 AC> where mydate = (select MAX(mydate) from table2)

 AC> Для update _в таком же стиле_, необходимо, чтоб сервер
 AC> поддерживал стандарт SQL-99, но многие сервера имеют
 AC> свои собственные расширения синтаксиса update.

Увы, кроме вложенного запроса и я ничего не придумал, кроме использования
временных таблиц. Postgre, кажется, понимает вложенные запросы в апдейтах, а
вот мыскль еще нет (только если в самой последней версии). А для моего мыскля
придется извращаться предварительной выборкой во временную таблицу.

Да?

Digitally yours, Alexey.

--- ifmail v.2.15dev5.3
 * Origin: FidoNet Online - http://www.fido-online.com (2:5020/400)
SEEN-BY: 46/50 50/203 520 450/159 186 1024 451/30 454/9 461/43 132 640 469/999
SEEN-BY: 4614/20 4616/3 4625/8 4627/10 5000/76 5000 5001/5001 5006/1 5007/1
SEEN-BY: 5010/53 70 5011/13 5012/23 5015/10 5019/31 5020/52 118 175 194 400
SEEN-BY: 5020/545 604 639 715 758 892 894 1042 1057 1200 1523 1604 1665 1909
SEEN-BY: 5020/1922 2013 2020 2238 4441 8383 5021/29 5025/3 750 5026/10 14 45
SEEN-BY: 5027/16 5029/32 5030/115 217 473 556 966 1063 1339 1900 5031/47
SEEN-BY: 5035/38 5036/1 34 5040/47 5042/13 5047/43 5049/1 5051/15 5054/1 8 9
SEEN-BY: 5054/28 35 37 45 63 67 5055/95 5057/1 5059/37 5060/88 5061/15 5062/1
SEEN-BY: 5066/18 5069/7 5070/1222 5079/23 5080/68 1003 5081/2 5082/6 5083/21
SEEN-BY: 5084/32 5085/13 5090/106 5092/1 5095/20 5099/4 133 6000/12 254 6009/1
PATH: 5020/400 4441 545 5054/1 37