Симптоми
След като инсталирате KB2982157, ако използвате функцията за подробна ДДС с повече от един партньор, общите суми за всеки партньор без да се нулира до нула в унгарски версия на Microsoft Dynamics NAV 2009 R2. Следвайте стъпките в раздела промени код за решаване на проблема. Този проблем възниква в следните продукти:
-
Унгарски версия на Microsoft Dynamics NAV 2009 R2
Решение
Информация за актуалната корекция
Вече се предлага от Microsoft предоставя поддържана актуална корекция. Обаче е предназначена само за коригиране на описания в тази статия. Прилагайте корекцията само към системи, изпитващи този конкретен проблем. Възможно е провеждането на допълнителни тестове на тази актуална корекция. Следователно ако не сте силно засегнати от този проблем, препоръчваме да изчакате следващия сервизен пакет за Microsoft Dynamics NAV 2009 или следващата версия на Microsoft Dynamics NAV, който ще съдържа тази корекция.
Забележка: При специални случаи таксите, които са за свързани с поддръжката обаждания могат да бъдат отменени, ако специалист по техническа поддръжка за Microsoft Dynamics и свързани с тях продукти определя, че конкретна актуализация може да разреши проблема. Обичайните такси за поддръжката ще важат за допълнителни въпроси и проблеми, които не спадат към съответната актуализация.
Информация за инсталирането
Microsoft предоставя примери само за илюстративни цели без гаранция за определени цели. Това включва, но не е ограничено до, подразбиращи се гаранции за продаваемост или годност за определена цел. Тази статия се предполага, че сте запознати с демонстрирания език за програмиране и инструментите, които се използват за създаване и процедури за отстраняване на грешки. Инженерите на поддръжката на Microsoft могат да помогнат обяснение на функциите на конкретна процедура. Въпреки това те няма да модифицират тези примери с цел осигуряване на допълнителна функционалност или създаване на процедури за удовлетворение на конкретните ви изисквания.
Забележка: Преди да инсталирате тази актуална корекция, уверете се, че всички потребители на клиента на Microsoft Dynamics NAV са излезли от системата. Това включва и услуги на Microsoft Dynamics NAV приложение сървър (NAS). Трябва да бъде само клиент потребител, който е влязъл при прилагане на тази актуална корекция.
За прилагане на тази актуална корекция, трябва да имате лиценз разработчик.
Препоръчително е потребителският акаунт в прозореца влизания в Windows или в прозореца на БД присвояването на "Супер" ИД на роля. Ако потребителският акаунт не може да бъде възложена ИД на роля на "Супер", трябва да проверите, че потребителският акаунт има следните права:
-
Разрешение за промяна на обекта, ще се променя.
-
Разрешението за изпълнение за системата обект номер 5210 обект и системата обект ID 9015
обект.
Забележка: Не трябва да имате права на съхранените данни, освен ако трябва да извършите възстановяване на данни.
Промени код
Забележка: Винаги тест код решава в управлявана среда преди да приложите корекциите производство компютри.
За да разрешите този проблем, изпълнете следните стъпки:
-
Да променяте списъчни ДДС извлечение (14522) както следва:
Съществуващ код...PartnerId := PartnerBuffer."Partner ID";
PartnerVatId := PartnerBuffer."VAT Registration No.";
PartnerName := GetPartnerName(PartnerType,PartnerId);
Buffer.RESET;
SetBufferFilters(PartnerType,PartnerId,PartnerVatId);
...Замени код
...PartnerId := PartnerBuffer."Partner ID";
PartnerVatId := PartnerBuffer."VAT Registration No.";
PartnerName := GetPartnerName(PartnerType,PartnerId);
// Add the following line.
PartnerBufferIsSet := TRUE;
// End of the added line.
Buffer.RESET;
SetBufferFilters(PartnerType,PartnerId,PartnerVatId);
... -
Да променяте променливите в списъчни ДДС извлечение (14522) както следва:
Съществуващ код 1...VAR
CompanyInfo@1170000002 : Record 79;
Buffer@1170000007 : TEMPORARY Record 14550;
PartnerBuffer@1170000008 : TEMPORARY Record 14551;
PartnerName@1170000012 : Text[250];
PartnerVatId@1170000013 : Text[30];
...Замени код 1
...VAR
CompanyInfo@1170000002 : Record 79;
Buffer@1170000007 : TEMPORARY Record 14550;
// Add the following line.
TempBuffer@1170000059 : TEMPORARY Record 14550;
// End of the added line.
PartnerBuffer@1170000008 : TEMPORARY Record 14551;
PartnerName@1170000012 : Text[250];
PartnerVatId@1170000013 : Text[30];
...Съществуващ код 2
...VatAmount6@1170000050 : Decimal;
TotalOf1365Mline@1170000057 : TextConst 'ENU=Total of %1 line %2';
TotalOf1365M@1170000058 : TextConst 'ENU=Total of %1';
PROCEDURE SetBuffer@1170000000(VAR Buff@1170000000 : Record 14550;StartPeriod@1170000001 : Date;EndPeriod@1170000002 : Date;VATThresholdAmt@1170000003 : Decimal);
BEGIN
...Замени код 2
...VatAmount6@1170000050 : Decimal;
TotalOf1365Mline@1170000057 : TextConst 'ENU=Total of %1 line %2';
TotalOf1365M@1170000058 : TextConst 'ENU=Total of %1';
// Add the following line.
PartnerBufferIsSet@1170000056 : Boolean;
// End of the added line.
PROCEDURE SetBuffer@1170000000(VAR Buff@1170000000 : Record 14550;StartPeriod@1170000001 : Date;EndPeriod@1170000002 : Date;VATThresholdAmt@1170000003 : Decimal);
BEGIN
... -
Да променяте CalcPartnerTotals функция в списъчни ДДС извлечение (14522) както следва:
Съществуващ код... LOCAL PROCEDURE CalcPartnerTotals@1170000006(VAR Buff@1170000003 : Record 14550;VAR NumInvoices@1170000001 : Integer;VAR VatBase@1170000002 : Decimal;VAR VatAmount@1170000004 : Decimal);
BEGIN
// Delete the following lines.
NumInvoices := Buff.COUNT;
IF Buff.FINDSET THEN
REPEAT
VatBase += ConvertToThousands(Buff."VAT Base");
VatAmount += ConvertToThousands(Buff."VAT Amount");
UNTIL Buff.NEXT = 0;
END;
LOCAL PROCEDURE CalcAllTotals@1170000015();
// End of the deleted lines.
...Замени код
...LOCAL PROCEDURE CalcPartnerTotals@1170000006(VAR Buff@1170000003 : Record 14550;VAR NumInvoices@1170000001 : Integer;VAR VatBase@1170000002 : Decimal;VAR VatAmount@1170000004 : Decimal);
BEGIN
// Add the following lines.
VatBase := 0;
VatAmount := 0;
NumInvoices := Buff.COUNT;
IF Buff.FINDSET THEN BEGIN
IF Buff."1365M" THEN BEGIN
IF PartnerBufferIsSet THEN BEGIN
Buff.CALCSUMS("VAT Base", "VAT Amount");
VatBase := ConvertToThousands(Buff."VAT Base");
VatAmount := ConvertToThousands(Buff."VAT Amount");
END ELSE BEGIN
REPEAT
VatAmount += CalcPartnerSubTotal(Buff."VAT Registration No.");
UNTIL Buff.NEXT = 0;
END;
END ELSE
REPEAT
VatBase += ConvertToThousands(Buff."VAT Base");
VatAmount += ConvertToThousands(Buff."VAT Amount");
UNTIL Buff.NEXT = 0;
END;
END;
LOCAL PROCEDURE CalcPartnerSubTotal@1170000004(VATRegNo@1170000000 : Text[20]) VatAmount : Decimal;
VAR
Buffer2@1170000001 : Record 14550;
EntryNo@1170000002 : Integer;
BEGIN
TempBuffer.RESET;
TempBuffer.SETRANGE("VAT Registration No.",VATRegNo);
IF NOT TempBuffer.FINDFIRST THEN BEGIN
EntryNo := 0;
TempBuffer.RESET;
IF TempBuffer.FINDLAST THEN
EntryNo := TempBuffer.EntryNo + 1;
TempBuffer.INIT;
TempBuffer.EntryNo := EntryNo;
TempBuffer."VAT Registration No." := VATRegNo;
TempBuffer.INSERT;
Buffer2.RESET;
Buffer2.SETRANGE("1365M-01");
Buffer2.SETRANGE("1365M-01K");
Buffer2.SETRANGE("1365M-02");
Buffer2.SETRANGE("1365M-02K");
Buffer2.SETRANGE("1365M",TRUE);
Buffer2.SETRANGE("K-Correction Type");
Buffer2.SETRANGE("VAT Registration No.",VATRegNo);
IF Buffer2.FINDSET THEN
REPEAT
VatAmount += Buffer2."VAT Amount";
UNTIL Buffer2.NEXT = 0;
EXIT(ConvertToThousands(VatAmount));
END;
END;
LOCAL PROCEDURE CalcAllTotals@1170000015();
// End of the added lines.
...
Необходими условия:
Трябва да имате един от следните продукти, за да приложите тази спешна корекция:
-
Унгарски версия на Microsoft Dynamics NAV 2009 R2
Освен това трябва да имате KB2982157 и MSDNAV2009R2ItemizedVAtHungary инсталиран.
Информация за премахване
Не можете да премахнете тази актуална корекция.
Статус
Microsoft потвърждава, че това е проблем в продуктите на Microsoft, изброени в раздела "Отнася се за".
Забележка: Това е статия "Бърза публикация", създадени директно от организацията за поддръжка на Microsoft. Информацията тук се предоставя "както-е" в отговор на появили се проблеми. В резултат на скоростта на предоставянето му материалите могат да съдържат печатни грешки и могат да бъдат коригирани по всяко време без предизвестие. Вижте Условияза други съображения.