AXForum  
Вернуться   AXForum > Microsoft Dynamics AX > DAX: Программирование
DAX
Забыли пароль?
Зарегистрироваться Правила Справка Пользователи Сообщения за день Поиск

 
 
Опции темы Поиск в этой теме Опции просмотра
Старый 15.02.2007, 12:20   #1  
KiselevSA is offline
KiselevSA
Злыдни
Аватар для KiselevSA
Злыдни
Лучший по профессии 2015
 
958 / 333 (13) ++++++
Регистрация: 25.01.2002
Адрес: Москва
А можно использовать в select ... maxof(CalculationDate)
__________________
люди...считают, что если техника не ломается, то ее не нужно ремонтировать. Инженеры считают, что если она не ломается, то нуждается в совершенствовании.
Старый 15.02.2007, 12:27   #2  
fialka is offline
fialka
Участник
 
347 / 16 (1) ++
Регистрация: 05.10.2006
Адрес: Екатеринбург
Цитата:
Сообщение от KiselevSA Посмотреть сообщение
А можно использовать в select ... maxof(CalculationDate)
да и desc нормально отрабатывает
Старый 15.02.2007, 12:32   #3  
KiselevSA is offline
KiselevSA
Злыдни
Аватар для KiselevSA
Злыдни
Лучший по профессии 2015
 
958 / 333 (13) ++++++
Регистрация: 25.01.2002
Адрес: Москва
Цитата:
Сообщение от fialka Посмотреть сообщение
да и desc нормально отрабатывает
Конечно, должна работать нормально.. Вот только сортировка не всегда быстрее выборки по условию. Надо бы посмотреть план запроса
__________________
люди...считают, что если техника не ломается, то ее не нужно ремонтировать. Инженеры считают, что если она не ломается, то нуждается в совершенствовании.
Старый 15.02.2007, 13:16   #4  
Zabr is offline
Zabr
Участник
Axapta Retail User
 
1,202 / 345 (14) ++++++
Регистрация: 26.06.2002
Адрес: Москва
оффтопик: а если бы была функция maxtime(), то мы бы узнали недокументированную особенность, что максимальное время, которое можно перевести в формат "hh:mm:ss" функцией time2str() - это почему-то 24 ч 59 мин 59 сек. Совершенно необъяснимое ограничение.
Старый 15.02.2007, 15:29   #5  
gl00mie is offline
gl00mie
Участник
MCBMSS
Most Valuable Professional
Лучший по профессии 2017
Лучший по профессии 2015
Лучший по профессии 2014
Лучший по профессии AXAWARD 2013
Лучший по профессии 2011
Лучший по профессии 2009
 
3,684 / 5813 (201) ++++++++++
Регистрация: 28.11.2005
Адрес: Москва
Записей в блоге: 3
Цитата:
Сообщение от Zabr Посмотреть сообщение
максимальное время, которое можно перевести в формат "hh:mm:ss" функцией time2str() - это почему-то 24 ч 59 мин 59 сек. Совершенно необъяснимое ограничение.
Думаю, объясняется все очень просто: time2str() проверяет допустимые диапазоны часов/минут/секунд независимо друг от друга, считая при это 24 часа допустимым значением.
Старый 16.02.2007, 15:21   #6  
Zuzaz is offline
Zuzaz
Участник
 
119 / 18 (1) ++
Регистрация: 22.09.2006
Цитата:
Сообщение от gl00mie Посмотреть сообщение
Думаю, объясняется все очень просто: time2str() проверяет допустимые диапазоны часов/минут/секунд независимо друг от друга, считая при это 24 часа допустимым значением.
Тем не менее, совершенно ненужное ограничение. Мне потребовалось измерить диапазон между двумя временами, которые могут быть в разных датах - и тут выясняется, что вывести временную разницу "25ч 30мин" в виде "25:30" стандартным средством нельзя.
Старый 15.02.2007, 16:30   #7  
Gad is offline
Gad
Участник
 
136 / 18 (1) ++
Регистрация: 21.05.2003
Адрес: Москва
Цитата:
Сообщение от KiselevSA Посмотреть сообщение
А можно использовать в select ... maxof(CalculationDate)
maxof - агрегирующая функция, тогда как в условии задачи надо получить запись с максимальной датой, а не саму максимальную дату.
Старый 15.02.2007, 17:07   #8  
DenNik is offline
DenNik
Участник
 
62 / 9 (1) +
Регистрация: 24.05.2005
Цитата:
Сообщение от Gad Посмотреть сообщение
maxof - агрегирующая функция, тогда как в условии задачи надо получить запись с максимальной датой, а не саму максимальную дату.
Агрегирвание - по сути объединение, может быть и несколько записей... Зная по какому принципу нам нужна группировка получаем нужный курсор (добавляя в запрос group by и дополнительные условия).
Старый 15.02.2007, 17:19   #9  
Gad is offline
Gad
Участник
 
136 / 18 (1) ++
Регистрация: 21.05.2003
Адрес: Москва
Цитата:
Сообщение от DenNik Посмотреть сообщение
Агрегирвание - по сути объединение, может быть и несколько записей... Зная по какому принципу нам нужна группировка получаем нужный курсор (добавляя в запрос group by и дополнительные условия).
не очень понял как при этом получть необходимое значение ADOQty, если оно числовое, надо будет написать sum(ADOQty)?, а нам нужно получить это количество из конкретной записи.
К тому же насчет group by - это не менее затратно с точки зрения производительности, чем order by, зато с order by, никаких доп. телодвижений не нужно
Старый 15.02.2007, 17:28   #10  
DenNik is offline
DenNik
Участник
 
62 / 9 (1) +
Регистрация: 24.05.2005
Цитата:
Сообщение от Gad Посмотреть сообщение
К тому же насчет group by - это не менее затратно с точки зрения производительности, чем order by, зато с order by, никаких доп. телодвижений не нужно
С group by тоже ничего не нужно лишнего - на счёт производительности спасибо - не знал ...

Цитата:
Сообщение от Gad Посмотреть сообщение
не очень понял как при этом получть необходимое значение ADOQty, если оно числовое, надо будет написать sum(ADOQty)?, а нам нужно получить это количество из конкретной записи.
Да. Или (если запись будет только одна(!)) делать дополнительный запрос, что, как мне кажется, не есть хорошо....
 

Похожие темы
Тема Автор Раздел Ответов Посл. сообщение
Бага в сопоставлении «Максимальная переплата или недоплата». Starling DAX: Функционал 1 03.04.2009 17:16
Максимальная длина типа String в DAX 4.0 alex55 DAX: Программирование 31 29.01.2009 15:33
Параметр "Максимальная дата закрытия".... soin DAX: Функционал 0 11.01.2006 14:18
Закупка. Дата получения документа. AlexeyBP DAX: Функционал 5 15.12.2005 16:53
Дата физ. проводки Yprit DAX: Функционал 4 17.12.2004 15:29

Ваши права в разделе
Вы не можете создавать новые темы
Вы не можете отвечать в темах
Вы не можете прикреплять вложения
Вы не можете редактировать свои сообщения

BB коды Вкл.
Смайлы Вкл.
[IMG] код Вкл.
HTML код Выкл.
Быстрый переход

Рейтинг@Mail.ru
Часовой пояс GMT +3, время: 07:35.