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

 
 
Опции темы Поиск в этой теме Опции просмотра
Старый 15.11.2005, 18:20   #1  
Yprit is offline
Yprit
Злыдни
Аватар для Yprit
Злыдни
 
419 / 93 (4) ++++
Регистрация: 22.02.2004
Адрес: СПб
Angry Резервирование при переносе
Столкнулся с ситуацией:
на складе есть 2 партии одной номенклатуры по 1 штуке в каждой партии
создаем журнал переноса на 2 штуки, в строках указываем только склад. Резервируем. Создаются 2 проводки прихода и 2 расхода, все корректно разбивается по партиям. Уменьшаем количество в журнал переноса до 1 штуки. Смотрим проводки - партии в проводке прихода и проводке расхода разные....

Изыскания привели меня к следующему куску кода в классе InventUpd_Estimated (методы updateDepreciateReceipt и updateDepreciateIssue):

PHP код:
 while select forupdate inventTrans
        index hint TransIdIdx
        order by statusReceipt desc
,inventRefTransId,inventDimId desc 
Т.е. получается, что сопоставление проводок прихода с расходом при уменьшении резерва идет не по комбинации складских аналитик, а по очередности создания записей в InventDim? Это нормальное поведение системы? Или я не понимаю всей хитрости данной схемы?
За это сообщение автора поблагодарили: kashperuk (5).
Старый 16.11.2005, 12:31   #2  
Yprit is offline
Yprit
Злыдни
Аватар для Yprit
Злыдни
 
419 / 93 (4) ++++
Регистрация: 22.02.2004
Адрес: СПб
Народ, ну неужели никто на эти грабли еще не наступал? Товар же с партии на партию мухой улетает
Старый 16.11.2005, 12:40   #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
У меня на вскидку в тестовой базе не воспроизвелось. Судя по всему, тут нужно особое стечение обстоятельств.

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

А вообще, судя по всему, очередная бага. Спасибо, что предупредили.
__________________
С уважением,
glibs®
Старый 16.11.2005, 13:16   #4  
Yprit is offline
Yprit
Злыдни
Аватар для Yprit
Злыдни
 
419 / 93 (4) ++++
Регистрация: 22.02.2004
Адрес: СПб
Спасибо, glibs!
Ситуация, при которой это вопсроизводится (вполне жизненная, во всяком случае для нас)
1. Приходуем 5 разных партий Товара по 1 штуке в каждой партии на Склад_1
2. Создаем резерв (любым складским журналом, я делал проводкой) 2-х штук Товара на Складе_1
3. Создаем перенос 5 штук Товара со Склада_1 на Склад_2
4. Резервируем (резервируется только 3 штуки, поскольку 2 штуки у нас зарезервированы ранее)
5. Лезем в журнал из пункта 2 и снимаем резерв 2-х штук
6. Возвращаемся в перенос и снова проводим резервирование (теперь зарезервированы все 5 штук)
7. В строке переноса уменьшаем количество (ну, допустим, не 5 штук, а только 3)
8. наблюдаем эффект, когда со Склада_1 уходят Партия 1, 2 и 3, а на Склад_2 приходят Партия 3,4 и 5.
Что соответствует очередности создания записей для Товара по Складу_1 и Складу_2 в таблице InventDim

"Прячась в лого свое
Волки воют 'Ё-Моё' ...
Старый 20.08.2008, 15:54   #5  
AvrDen is offline
AvrDen
Участник
 
134 / 26 (1) +++
Регистрация: 04.08.2005
Адрес: Усть-Каменогорск
Похоже в 4-ке эту проблему не устранили...
Столкнулся с такой ситуацией: на складе по одной ном-ре имеется кол-во 10 шт.(с номером партии П1). Пользователи создают журнал переноса по этой ном-ре с кол-ом 20 шт. В итоге у нас создаються 4 проводки(Проводки расхода - Физ.зарезервировано 10 шт с партией П1 и Заказано 10 шт без партии, Проводки прихода Заказано 10 шт. с Партией П1 и Заказано 10 шт. без партии). Далее пользователь уменьшает кол-во до 10 шт. В итоге остаються 2 проводки(Проводки расхода - Физ.зарезервировано 10 шт с партией П1, проводки прихода - Заказано 10 шт. без партии). Важный момент в том что код аналитики у аналитик с заполным номером партии у нас всегда больше чем код аналитики без номера партии...
Поэтому в методе InventUpd_Estimated\updateDepreciateReceipt
X++:
                    select forupdate inventTrans
                        index hint TransIdIdx
                        order by StatusReceipt desc, InventDimId desc
                        where inventTrans.InventTransId         == movement.transId()               &&
                              inventTrans.TransChildType        == movement.transChildType()        &&
                              inventTrans.TransChildRefId       == movement.transChildRefId()       &&
                              inventTrans.StatusIssue           == StatusIssue::None                &&
                              inventTrans.StatusReceipt         >= StatusReceipt::Ordered           &&
                              inventTrans.StatusReceipt         <= StatusReceipt::QuotationReceipt  &&
                              inventTrans.InventRefTransId      == '';
удаляеться проводка прихода с номером партии.
И в результате получаеться что товар ушел с номером партии, а пришел без номера.
Кто-нибудь подскажет как решить эту проблему?
Старый 20.08.2008, 16:16   #6  
kashperuk is offline
kashperuk
Участник
Аватар для kashperuk
MCBMSS
Соотечественники
Сотрудники Microsoft Dynamics
Лучший по профессии 2017
Лучший по профессии 2015
Лучший по профессии 2014
Лучший по профессии 2011
Лучший по профессии 2009
 
4,361 / 2084 (78) +++++++++
Регистрация: 30.05.2004
Адрес: Atlanta, GA, USA
Цитата:
Сообщение от AvrDen Посмотреть сообщение
Похоже в 4-ке эту проблему не устранили...
Столкнулся с такой ситуацией: на складе по одной ном-ре имеется кол-во 10 шт.(с номером партии П1). Пользователи создают журнал переноса по этой ном-ре с кол-ом 20 шт. В итоге у нас создаються 4 проводки(Проводки расхода - Физ.зарезервировано 10 шт с партией П1 и Заказано 10 шт без партии, Проводки прихода Заказано 10 шт. с Партией П1 и Заказано 10 шт. без партии). Далее пользователь уменьшает кол-во до 10 шт. В итоге остаються 2 проводки(Проводки расхода - Физ.зарезервировано 10 шт с партией П1, проводки прихода - Заказано 10 шт. без партии). Важный момент в том что код аналитики у аналитик с заполным номером партии у нас всегда больше чем код аналитики без номера партии...
Поэтому в методе InventUpd_Estimated\updateDepreciateReceipt
X++:
                    select forupdate inventTrans
                        index hint TransIdIdx
                        order by StatusReceipt desc, InventDimId desc
                        where inventTrans.InventTransId         == movement.transId()               &&
                              inventTrans.TransChildType        == movement.transChildType()        &&
                              inventTrans.TransChildRefId       == movement.transChildRefId()       &&
                              inventTrans.StatusIssue           == StatusIssue::None                &&
                              inventTrans.StatusReceipt         >= StatusReceipt::Ordered           &&
                              inventTrans.StatusReceipt         <= StatusReceipt::QuotationReceipt  &&
                              inventTrans.InventRefTransId      == '';
удаляеться проводка прихода с номером партии.
И в результате получаеться что товар ушел с номером партии, а пришел без номера.
Кто-нибудь подскажет как решить эту проблему?
Что-то не удалось воспроизвести это на АХ 2009, хотя вроде код здесь не менялся. До смены кол-ва все ОК, тоже 4 проводки, в двух не указана партия. А вот когда меняю кол-во, остается 2, в обоих указана партия. Что-то может забыли написать, что необходимо сделать?
Старый 20.08.2008, 17:07   #7  
Yprit is offline
Yprit
Злыдни
Аватар для Yprit
Злыдни
 
419 / 93 (4) ++++
Регистрация: 22.02.2004
Адрес: СПб
Цитата:
Сообщение от kashperuk Посмотреть сообщение
Что-то может забыли написать, что необходимо сделать?
AvrDem Важный момент в том что код аналитики у аналитик с заполным номером партии у нас всегда больше чем код аналитики без номера партии

Yprit Что соответствует очередности создания записей для Товара по Складу_1 и Складу_2 в таблице InventDim
Старый 20.08.2008, 17:24   #8  
altap is offline
altap
MCTS
MCBMSS
 
26 / 18 (1) ++
Регистрация: 28.09.2005
Такую сортировку можно наблюдать и в других классах семейства InventUpd*. Насколько я понимаю упорядочивание по номеру аналитики необходимо, чтобы обеспечить некоторое подобие LIFO при увеличении и уменьшении количества в журнале, дабы не создавать путаницы.
Старый 20.08.2008, 17:51   #9  
Logger is offline
Logger
Участник
Лучший по профессии 2015
Лучший по профессии 2014
 
3,941 / 3229 (115) ++++++++++
Регистрация: 12.10.2004
Адрес: Москва
Записей в блоге: 2
Ваня, а можешь проверить, у приходных проводок в переносе статус одинаковый был ?
По идее если одинаковый и
совпадают
X++:
inventTrans.TransChildType                              
inventTrans.TransChildRefId
inventTrans.InventRefTransId      == ''
то должен был баг воспроизвестись.

Либо тебе повезло с номерами аналитик InventDimID - так что отсортировалось так что проводки с заполненной партией первыми подцепились
Старый 20.08.2008, 18:10   #10  
Logger is offline
Logger
Участник
Лучший по профессии 2015
Лучший по профессии 2014
 
3,941 / 3229 (115) ++++++++++
Регистрация: 12.10.2004
Адрес: Москва
Записей в блоге: 2
Предлагаю перед тем как воспроизводить глюк создать аналитики вот таким джобом

X++:
static void Job378(Args _args)
{
    #define.inventBatchId1("BatchID1")
    #define.inventBatchId2("BatchID2")
    #define.InventLocationIDFrom("From")
    #define.InventLocationIDTO("To")
    InventDim       InventDim;
    ;
    ttsBegin;
    InventDim.InventLocationId = #InventLocationIDFrom;
    InventDim.inventBatchId    = #inventBatchId1;
    InventDim::findOrCreate(InventDim);
    InventDim.clear();

    InventDim.InventLocationId = #InventLocationIDFrom;
    InventDim.inventBatchId    = #inventBatchId2;
    InventDim::findOrCreate(InventDim);
    InventDim.clear();

    InventDim.InventLocationId = #InventLocationIDTo;
    InventDim.inventBatchId    = #inventBatchId2;
    InventDim::findOrCreate(InventDim);
    InventDim.clear();

    InventDim.InventLocationId = #InventLocationIDTo;
    InventDim.inventBatchId    = #inventBatchId1;
    InventDim::findOrCreate(InventDim);
    InventDim.clear();
    ttsCommit;
}
затем на обе аналитики поднять остатки и попробовать пример Yprit

Должно сработать.

P.S. В данном джобе я просто заранее создаю аналитики с нужным порядком следования InventDimId, чтобы на одном складе с большему значению InventBatch соответствовало большее значение InventDimID а на другом складе наоборот.

В ax4.0 и ax5.0 может помешать тот факт что выравнивание InventDimID левое - в этом случае нужно убедиться что джоб правильно создал все. - Проблема может возникнуть, если при выделении номера аналитики - число значащих цифр увеличится. Для правого выравнивания гарантировано должно воспроизвестись.

(в общем проще свои номера InventDimId константами пробить)

Последний раз редактировалось Logger; 20.08.2008 в 18:17.
За это сообщение автора поблагодарили: kashperuk (5).
Старый 20.08.2008, 18:11   #11  
Logger is offline
Logger
Участник
Лучший по профессии 2015
Лучший по профессии 2014
 
3,941 / 3229 (115) ++++++++++
Регистрация: 12.10.2004
Адрес: Москва
Записей в блоге: 2
Указанные примеры могут показаться экзотическими случаями. Но у нас в реальной работе за несколько месяцев создалось несколько сотен лотов с такой пересортицей. Потом было очень геморно исправлять эту пересортицу, особенно после того как товары уже продали и остатки по аналитикам обнулились.
Старый 20.08.2008, 19:54   #12  
kashperuk is offline
kashperuk
Участник
Аватар для kashperuk
MCBMSS
Соотечественники
Сотрудники Microsoft Dynamics
Лучший по профессии 2017
Лучший по профессии 2015
Лучший по профессии 2014
Лучший по профессии 2011
Лучший по профессии 2009
 
4,361 / 2084 (78) +++++++++
Регистрация: 30.05.2004
Адрес: Atlanta, GA, USA
Да, проблему воспроизвел. Спасибо
Интересно узнать, как боретесь?
Как-то влияет это на себестоимость? Я понимаю, что себестоимость товара из партии2 на втором складе изменяется в зависимости от себестоимости товара из партии1 со склада1. Насколько это критично?
Старый 20.08.2008, 20:15   #13  
Vals is offline
Vals
Аманд
Аватар для Vals
Компания АМАНД
Лучший по профессии 2015
Лучший по профессии 2014
Лучший по профессии AXAWARD 2013
Лучший по профессии 2009
 
1,766 / 507 (20) +++++++
Регистрация: 27.02.2002
Адрес: Pass partout, Москва
Ребят, расскажите, как в ваших примерах настроена аналитика?
1. Первичная/Вторичная
2. В складских моделях фифо/лифо для резервирования
3. В параметрах резервирование заказанного
4. Процедура создания номера партии (автосоздание).
Старый 20.08.2008, 20:24   #14  
Logger is offline
Logger
Участник
Лучший по профессии 2015
Лучший по профессии 2014
 
3,941 / 3229 (115) ++++++++++
Регистрация: 12.10.2004
Адрес: Москва
Записей в блоге: 2
Цитата:
Сообщение от kashperuk Посмотреть сообщение
Да, проблему воспроизвел. Спасибо
Интересно узнать, как боретесь?
Как-то влияет это на себестоимость? Я понимаю, что себестоимость товара из партии2 на втором складе изменяется в зависимости от себестоимости товара из партии1 со склада1. Насколько это критично?
Да, конечно на себестоимость влияет. Если честно - это очень критично. Мне кажется, что из-за этого бага, вообще некорректно говорить о том что себестоимость считается в разрезе аналитик. (Еще есть баг, когда при переносах нескольких партий себестоимость усредняется по ним. Аналогично и при оформлении заказа на возврат, когда заполнениется лот возврата. - Правда это уже другой баг )

Лечили так.
У нас принят партионный учет для всех номенклатур.
Соответственно, когда в InventJournalTrans.Update() стоит вызов
X++:
        estimated = new InventUpd_Estimated(InventMovement::construct(this));
        estimated.updateNow();

        if (this.JournalType == InventJournalType::Transfer)
        {
            estimatedTransfer = new InventUpd_Estimated(InventMovement::construct(this,true));
            estimatedTransfer.updateNow();
        }
то в первом вызове
X++:
estimated.updateNow()
запоминали пары [аналитика, дельта количества]

Передавали полученную инфу во второй вызов
X++:
estimatedTransfer.updateNow();
и там уже при работе InventUpd_Estimated\updateDepreciateReceipt
учитывали эту информацию, так чтобы цеплялась нужная партия и на нужное количество.

Думаю, что можно обобщить такой подход на произвольную аналитику. Добавить в группу складской аналитики еще одну галку, при помощи которой и определять - какую комбинацию аналитик сохранять при редактировании переноса.

P.S. Ax 3.0
За это сообщение автора поблагодарили: player (1).
Старый 20.08.2008, 20:28   #15  
Logger is offline
Logger
Участник
Лучший по профессии 2015
Лучший по профессии 2014
 
3,941 / 3229 (115) ++++++++++
Регистрация: 12.10.2004
Адрес: Москва
Записей в блоге: 2
Цитата:
Сообщение от Vals Посмотреть сообщение
Ребят, расскажите, как в ваших примерах настроена аналитика?
1. Первичная/Вторичная
2. В складских моделях фифо/лифо для резервирования
3. В параметрах резервирование заказанного
4. Процедура создания номера партии (автосоздание).
Мне кажется, что ни один из этих параметров не должен влиять на воспроизводимость глюка. (Ну разве что склад и партия должны быть включены, если говорить о примере который я привел)
Старый 20.08.2008, 23:02   #16  
kashperuk is offline
kashperuk
Участник
Аватар для kashperuk
MCBMSS
Соотечественники
Сотрудники Microsoft Dynamics
Лучший по профессии 2017
Лучший по профессии 2015
Лучший по профессии 2014
Лучший по профессии 2011
Лучший по профессии 2009
 
4,361 / 2084 (78) +++++++++
Регистрация: 30.05.2004
Адрес: Atlanta, GA, USA
А какие еще проблемы, кроме неправильной себестоимости, возникают, если не исправить эту ошибку?

Неправильная себестоимость, насколько я понимаю, возникает только в случае, если аналитика Партия активирована как финансовая (в противном случае она все равно считается в разрезе склада). Или нет?
Старый 21.08.2008, 08:45   #17  
Yprit is offline
Yprit
Злыдни
Аватар для Yprit
Злыдни
 
419 / 93 (4) ++++
Регистрация: 22.02.2004
Адрес: СПб
Цитата:
Сообщение от Vals Посмотреть сообщение
Ребят, расскажите, как в ваших примерах настроена аналитика?
1. Первичная/Вторичная
2. В складских моделях фифо/лифо для резервирования
3. В параметрах резервирование заказанного
4. Процедура создания номера партии (автосоздание).
Ох, давно это было.... И посмотреть негде...
1. склад, партия, серийный номер (по-моему, было так)
2. Фифо
3. Выключено
4. Да

Цитата:
Сообщение от kashperuk Посмотреть сообщение
Да, проблему воспроизвел. Спасибо
Интересно узнать, как боретесь?
Как-то влияет это на себестоимость? Я понимаю, что себестоимость товара из партии2 на втором складе изменяется в зависимости от себестоимости товара из партии1 со склада1. Насколько это критично?
Опять же, точно не скажу, но по-моему я сузил критерии выбора проводок, добавив #inventDimJoin и проинициализировав inventDimParm. Особо глубоко копать времени тогда не было, а багов в последующем от подобной модификации явных не вылезло

Относительно себестоимости - с переносами там вообще все довольно зыбко, во всяком случае с точки зрения партионного учета в его российском понимании. Я имею в виду знаменитое усредненине себестоимости в разрезе партий при резервирвании лотов. В самом начале внедрения мне кто-то из великих по этому поводу втолковывал... да, fed - вот здесь. В общем, с помощью этого способа (автоподстановка аналитики в строки журнала переноса, по кнопке и т.п.) и боролись в том числе.

ОФФ: посмотрел свои вопросы 2004 года - как, однако, много воды утекло :-) Спасибо вам, форумчане, гуру наши - чтоб я без вас тогда делал! Просто за руку водили :-)
Старый 21.08.2008, 08:48   #18  
Yprit is offline
Yprit
Злыдни
Аватар для Yprit
Злыдни
 
419 / 93 (4) ++++
Регистрация: 22.02.2004
Адрес: СПб
Цитата:
Сообщение от kashperuk Посмотреть сообщение
А какие еще проблемы, кроме неправильной себестоимости, возникают, если не исправить эту ошибку?
Сама неприянтая ошибка - это когда надо перед поставщиком о реализации отчитываться по условиям договора... Черт бы с ней, с себестоимостью - можно коррекцией исправить, в конце концов. А вот то, что партии у товара меняются - это были очень большие грабли в нашем случае.
Старый 21.08.2008, 09:55   #19  
AvrDen is offline
AvrDen
Участник
 
134 / 26 (1) +++
Регистрация: 04.08.2005
Адрес: Усть-Каменогорск
Цитата:
Сообщение от Yprit Посмотреть сообщение
Сама неприянтая ошибка - это когда надо перед поставщиком о реализации отчитываться по условиям договора... Черт бы с ней, с себестоимостью - можно коррекцией исправить, в конце концов. А вот то, что партии у товара меняются - это были очень большие грабли в нашем случае.
Да у нас сейчас такая же беда.

Исправил эту ситуацию следующим образом(может немного коряво, но работает):
При удалении расходной проводки запоминаю InventDim и InventDimParm, и передаю их в InventUpd_Estimated\updateDepreciateReceipt. В InventDim заменяю склад, на склад прихода.
Старый 21.08.2008, 13:23   #20  
Vals is offline
Vals
Аманд
Аватар для Vals
Компания АМАНД
Лучший по профессии 2015
Лучший по профессии 2014
Лучший по профессии AXAWARD 2013
Лучший по профессии 2009
 
1,766 / 507 (20) +++++++
Регистрация: 27.02.2002
Адрес: Pass partout, Москва
Цитата:
Мне кажется, что ни один из этих параметров не должен влиять на воспроизводимость глюка
Вообще, по логике должны влиять. Я пока не занимался этим вопросом - после отпуска, на курсах дам студентам такую задачку - посмотрим что получится

О влиянии: первичная аналитика влияет на перерезервирование, автосоздание номера партии влияет на создание новых номеров при создании новых строк и проводок (при этом влияют параметры автосоздания - в строках, проводках и т.д.).
Теги
bug, журнал, перемещение, резервирование, crm2011

 

Похожие темы
Тема Автор Раздел Ответов Посл. сообщение
Автоматическое резервирование: на тропе войны aevi82 DAX: Функционал 11 29.08.2007 16:35
Ручное резервирование в заказах aevi82 DAX: Функционал 1 02.06.2006 10:36
автоматическое резервирование с учетом отборочной накладной anny DAX: Функционал 1 20.07.2005 22:21
Резервирование в заказанных (серия 5) Dana DAX: Функционал 8 14.05.2004 14:37
СП: Резервирование в спланированном переносе Hamster DAX: Функционал 3 19.02.2004 10:57
Опции темы Поиск в этой теме
Поиск в этой теме:

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

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

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

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