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

 
 
Опции темы Поиск в этой теме Опции просмотра
Старый 09.04.2016, 07:04   #1  
arhat is offline
arhat
Участник
 
116 / 16 (1) ++
Регистрация: 10.11.2014
Адрес: Казахстан
Angry Ошибка в запросе
Добрый день! Скажите пожалуйста почему в инвент трансе не выбирается количество,
X++:
qbdsInventTrans = query.addDataSource(tableNum(InventTrans));
    qbdsInventTrans.orderMode(OrderMode::GroupBy);
    qbdsInventTrans.addSelectionField(fieldNum(InventTrans,Qty),SelectionField::Sum);
    qbdsInventTrans.addSelectionField(fieldNum(InventTrans,CostAmountPosted),SelectionField::Sum);
    qbdsInventTrans.addSelectionField(fieldNum(InventTrans,CostAmountAdjustment),SelectionField::Sum);
    qbdsInventTrans.addRange(fieldNum(InventTrans,Qty)).value(strfmt("!=%1",0));
    qbdsInventTrans.addRange(fieldNum(InventTrans,statusReceipt)).value(strfmt("<=%1",StatusReceipt::Received));
    qbdsInventTrans.addRange(fieldNum(InventTrans,statusIssue)).value(strfmt("<=%1",StatusIssue::Sold));

    qbdsInventTable = qbdsInventTrans.addDataSource(tableNum(InventTable));
    qbdsInventTable.orderMode(OrderMode::GroupBy);
    qbdsInventTable.addSortField(fieldNum(InventTable,ItemId));
    qbdsInventTable.addSortField(fieldNum(InventTable,ItemType));
    qbdsInventTable.joinMode(JoinMode::InnerJoin);
    qbdsInventTable.fetchMode(QueryFetchMode::One2One);
    qbdsInventTable.relations(true);
    
    qbdsInventDim = qbdsInventTrans.addDataSource(tableNum(InventDim));
    qbdsInventDim.orderMode(OrderMode::GroupBy);
    qbdsInventDim.addSortField(fieldNum(InventDim,InventBatchId));
    qbdsInventDim.addSelectionField(fieldNum(InventDim,InventBatchId));
    qbdsInventDim.joinMode(JoinMode::InnerJoin);
    qbdsInventDim.fetchMode(QueryFetchMode::One2One);
    qbdsInventDim.relations(true);

    qbdsInventTransOrigin = qbdsInventTrans.addDataSource(tableNum(InventTransOrigin));
    qbdsInventTransOrigin.orderMode(OrderMode::GroupBy);
    qbdsInventTransOrigin.addSortField(fieldNum(InventTransOrigin,ReferenceCategory));
    qbdsInventTransOrigin.addSelectionField(fieldNum(InventTransOrigin,ReferenceCategory));
    qbdsInventTransOrigin.joinMode(JoinMode::InnerJoin);
    qbdsInventTransOrigin.fetchMode(QueryFetchMode::One2One);
    qbdsInventTransOrigin.relations(true);

    qbdsInventJournalTable =  qbdsInventTransOrigin.addDataSource(tableNum(InventJournalTable));
    qbdsInventJournalTable.orderMode(OrderMode::GroupBy);
    qbdsInventJournalTable.addSortField(fieldNum(InventJournalTable,JournalId));   
    qbdsInventJournalTable.joinMode(JoinMode::InnerJoin);
    qbdsInventJournalTable.fetchMode(QueryFetchMode::One2One);
    qbdsInventJournalTable.addLink(fieldNum(InventTransOrigin,ReferenceId),fieldNum(InventJournalTable,JournalId));
    qbdsInventJournalTable.addRange(fieldnum(InventJournalTable, DKL_TransDate)).value(queryrange(dateFrom, dateTo));
    qbdsInventJournalTable.addRange(fieldnum(InventJournalTable, Posted)).value(queryValue(NoYes::Yes));
    qbdsInventJournalTable.addRange(fieldnum(InventJournalTable, JournalType)).value(queryvalue(InventJournalType::Transfer));
    qrType      = qbdsInventJournalTable.addRange(fieldnum(InventJournalTable, MEL_OperationType));
       
    qbdsInventLocationFrom = qbdsInventJournalTable.addDataSource(tablenum(InventLocation));
    qbdsInventLocationFrom.orderMode(OrderMode::GroupBy);
    qbdsInventLocationFrom.addSortField(fieldNum(InventLocation,InventLocationId));
    qbdsInventLocationFrom.addSortField(fieldNum(InventLocation,Name));
    qbdsInventLocationFrom.addSortField(fieldNum(InventLocation,InventLocationType));
    qbdsInventLocationFrom.joinMode(JoinMode::InnerJoin);
    qbdsInventLocationFrom.fetchMode(QueryFetchMode::One2One);
    qbdsInventLocationFrom.addLink(fieldnum(InventJournalTable, DKL_InventLocationId), fieldnum(InventLocation, InventLocationId));
    
    qbdsInventLocationTo = qbdsInventJournalTable.addDataSource(tablenum(InventLocation));
    qbdsInventLocationTo.orderMode(OrderMode::GroupBy);
    qbdsInventLocationTo.addSortField(fieldNum(InventLocation,InventLocationId));
    qbdsInventLocationTo.addSortField(fieldNum(InventLocation,Name));
    qbdsInventLocationTo.addSortField(fieldNum(InventLocation,InventLocationType));
    qbdsInventLocationTo.joinMode(JoinMode::InnerJoin);
    qbdsInventLocationTo.fetchMode(QueryFetchMode::One2One);
    qbdsInventLocationTo.addLink(fieldnum(InventJournalTable, DKL_InventLocationIdTo), fieldnum(InventLocation, InventLocationId));
Далее идут ренжи по типам склада в зависимости от ситуатций! Все поля в остальных таблицах находит кроме полей в InventTrans!!!
Старый 09.04.2016, 09:40   #2  
gl00mie is offline
gl00mie
Участник
MCBMSS
Most Valuable Professional
Лучший по профессии 2017
Лучший по профессии 2015
Лучший по профессии 2014
Лучший по профессии AXAWARD 2013
Лучший по профессии 2011
Лучший по профессии 2009
 
3,684 / 5798 (201) ++++++++++
Регистрация: 28.11.2005
Адрес: Москва
Записей в блоге: 3
Цитата:
Сообщение от arhat Посмотреть сообщение
Добрый день! Скажите пожалуйста почему в инвент трансе не выбирается количество,
X++:
qbdsInventTrans.addSelectionField(fieldNum(InventTrans,Qty),SelectionField::Sum);
qbdsInventTrans.addSelectionField(fieldNum(InventTrans,CostAmountPosted),SelectionField::Sum);
qbdsInventTrans.addSelectionField(fieldNum(InventTrans,CostAmountAdjustment),SelectionField::Sum);
qbdsInventTrans.addRange(fieldNum(InventTrans,Qty)).value(strfmt("!=%1",0));
qbdsInventTrans.addRange(fieldNum(InventTrans,statusReceipt)).value(strfmt("<=%1",StatusReceipt::Received));
qbdsInventTrans.addRange(fieldNum(InventTrans,statusIssue)).value(strfmt("<=%1",StatusIssue::Sold));
Все поля в остальных таблицах находит кроме полей в InventTrans!!!
С учетом того, как вы фильтруете выборку по InventTrans, рискну предположить, что ваши приходные и расходные проводки при группировке схлопываются в ноль. Для проверки попробуйте добавить выборку count(RecId) для InventTrans.
Старый 09.04.2016, 09:46   #3  
arhat is offline
arhat
Участник
 
116 / 16 (1) ++
Регистрация: 10.11.2014
Адрес: Казахстан
Цитата:
Сообщение от gl00mie Посмотреть сообщение
С учетом того, как вы фильтруете выборку по InventTrans, рискну предположить, что ваши приходные и расходные проводки при группировке схлопываются в ноль. Для проверки попробуйте добавить выборку count(RecId) для InventTrans.
Да схлопвались в ноль! Проблему решил другим способом. Сделал проверку на склады не в запросе, но очень интересно, потому что этот запрос работал на ax 2009. а на 2012 сделал джойн InventTransOrigin в остальном все в одни в один.
Старый 09.04.2016, 10:13   #4  
S.Kuskov is offline
S.Kuskov
Участник
Лучший по профессии 2017
Лучший по профессии 2015
Лучший по профессии 2014
 
3,437 / 1775 (66) ++++++++
Регистрация: 28.04.2007
Адрес: Калуга
Вы склады достаёте из шапок журнала? Почему не из проводок?
Старый 09.04.2016, 11:00   #5  
arhat is offline
arhat
Участник
 
116 / 16 (1) ++
Регистрация: 10.11.2014
Адрес: Казахстан
Цитата:
Сообщение от S.Kuskov Посмотреть сообщение
Вы склады достаёте из шапок журнала? Почему не из проводок?
нужно делить приход и расход, через транзитный склад, получается два журнала нужно объединить в одну выгрузку и удалить проводки транзитного
Теги
запросы

 

Похожие темы
Тема Автор Раздел Ответов Посл. сообщение
Ошибка в запросе - Почему не работает?? Art_Tanis DAX: Программирование 3 15.09.2014 15:00
Ошибка в логе при установке клиента AX 2009 sao DAX: Администрирование 9 04.02.2010 11:56
Ошибка в запросе sergy DAX: Программирование 6 18.10.2005 16:38
Русская локализация Axapta 3 ? SlavaK DAX: Администрирование 59 01.07.2003 22:38
ошибка в запросе mick_777 DAX: Программирование 3 10.07.2002 10:40
Опции темы Поиск в этой теме
Поиск в этой теме:

Расширенный поиск
Опции просмотра

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

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

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