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

 
 
Опции темы Поиск в этой теме Опции просмотра
Старый 13.08.2007, 22:29   #1  
gl00mie is offline
gl00mie
Участник
MCBMSS
Most Valuable Professional
Лучший по профессии 2017
Лучший по профессии 2015
Лучший по профессии 2014
Лучший по профессии AXAWARD 2013
Лучший по профессии 2011
Лучший по профессии 2009
 
3,684 / 5798 (201) ++++++++++
Регистрация: 28.11.2005
Адрес: Москва
Записей в блоге: 3
Косячок в классе InventAdj_Cancel (fetchMode)
Наткнулся сегодня на «интересный» способ указывать fetchMode в Query. Так, в методе InventAdj_Cancel.updateMultipleInvent() есть такие интересные строчки (AX 3.0 SP5 FP1)
X++:
inventSettlementDataSource = inventClosingDataSource.addDataSource(
                                        tableNum(InventSettlement));
inventSettlementDataSource.fetchMode(JoinMode::INNERJOIN);
Ну, казалось бы, ерунда, JoinMode::InnerJoin = 1 == QueryFetchMode::One2One, но далее в том же методе код еще интереснее
X++:
inventTransDataSource = inventSettlementDataSource.addDataSource(
                                        TableNum(InventTrans));
inventTransDataSource.fetchMode(JoinMode::ExistsJoin);
Я подозреваю, что Axapta при обработке свойства fetchMode делает проверку типа
X++:
if(fetchMode) { /* выборка 1:1 */ }
т.е. ей, возможно, плевать, что значению 2 никакой QueryFetchMode не соответствует, однако, использование «левых» констант в стандартном коде как-то смущает Решил на всякий случай проверить Inventory Closing Rollup 2 для AX 3.0 и код в AX 4.0 SP1. В первом случае указанный метод класса InventAdj_Cancel модификации не подвергся, а вот в 4-ке совсем интересно: вместо JoinMode::INNERJOIN там красуется JoinMode::InnerJoin, т.е., видимо, код «подчищали» (хотя бы в плане регистра идентификаторов и ключевых слов - всякие «TableNum» канули в Лету), но значения констант оставили прежними: там все так же красуется fetchMode(JoinMode::ExistsJoin)
Использование JoinMode::InnerJoin в AX 3.0 SP5 FP1 для установки fetchMode встречается еще в методах RAssetCreateTaxAccount.new() и Tax.queryTaxCodeIntersection(), JoinMode::ExistsJoin для этого вроде, к счастью, нигде больше не используется.
За это сообщение автора поблагодарили: Logger (2), vladz (1).
Старый 13.08.2007, 23:49   #2  
EVGL is offline
EVGL
Banned
Соотечественники
Лучший по профессии 2017
Лучший по профессии 2015
Лучший по профессии 2014
 
4,445 / 3001 (0) ++++++++++
Регистрация: 09.07.2002
Адрес: Parndorf, AT
Да. Смешно читать, как M. F. Pontoppidan надувает щеки и с гордостью пишет, что в версии 4.0 устранены все отклонения от Best Practices. Во-первых, не устранены, а во-вторых, все это сделали чисто механически, и с прикладной точки зрения код едва ли улучшился.

Мне это отдаленно напоминает одного программиста-дуболома из бывшего австрийского Коламбуса. При переходе на 3.0, как вы помните, проверка на ttsbegin перед .update() была ужесточена. Так этот кретин выгрузил весь код из VAR-слоя в XPO (!) и в текстовом редакторе обрамил все вызовы:

ttsbegin;
xxx.update();
ttscommit;

Нетрудно догадаться, что приложение перестало работать совсем.

Последний раз редактировалось EVGL; 13.08.2007 в 23:55.
Старый 14.08.2007, 00:46   #3  
glibs is offline
glibs
Member
Сотрудники компании It Box
Most Valuable Professional
Лучший по профессии 2011
Лучший по профессии 2009
 
4,942 / 911 (40) +++++++
Регистрация: 10.06.2002
Адрес: I am from Kyiv, Ukraine. Now I am in Moscow. For private contacts: glibs@hotmail.com
Цитата:
Сообщение от EVGL
...
в версии 4.0 устранены все отклонения от Best Practices.
...
Где???!!!

Скомпилируйте какой-нибудь класс Global...

Только это... Нажмите сначала Сервис\Параметры, кнопочка Компилятор, в поле Уровень диагностики Уровень 4. Только это не все. Потом Кнопочка Рекомендации и в самом верху в поле Уровень предупреждения выберите Все, а не Ошибки.

983 отклонений от ВР.

Или мой "любимый" класс WebFormHtml

1100 отклонений от ВР.

Причем если в Global в восточноевропейской версии может быть код локализаторов (лень смотреть, но раньше был), то в WebFormHtml они точно не лазили.

Так чего они там такого "сделали" с отклонениями? По умолчанию проверку по ВР попросили сообщать только об ошибках?
__________________
С уважением,
glibs®
Теги
ax3.0, ax4.0

 

Похожие темы
Тема Автор Раздел Ответов Посл. сообщение
Баг в системном классе SysOperationProgressBase. Hyper DAX: Прочие вопросы 0 19.03.2009 18:58
args в классе от RunBase Zoe DAX: Программирование 5 11.12.2008 18:20
Баг (?) в классе LedgerBalanceDim Peter Savintsev DAX: Программирование 3 18.06.2008 05:41
Кэш в классе Specification Hyper DAX: Программирование 0 12.04.2008 18:52
Как в наследуемом классе кл. RunBase перехватывать модиф. полей м.Prompt() alef_nor DAX: Программирование 2 11.05.2006 15:07

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

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

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