В тази статия се отнася за Microsoft Dynamics NAV за езиковата променлива на унгарски (hu) език.
Симптоми
Да разгледаме следния сценарий в унгарски версия на Microsoft Dynamics NAV 2009 R2:
-
Приложите актуализацията на авансови плащания за английски версия на Microsoft Dynamics NAV 2009 R2.
-
Задавате вид авансови плащания за предварително във формуляра за настройка за счетоводство.
-
Задавате Adv. фактурата корекция тип поле за абсолютни за начислява ДДС счетоводна група.
-
Създавате поръчки за продажби за клиент, който използва ДДС счетоводна група.
-
Изпращате авансово и предварително фактура за клиента.
-
Доставят и фактуриране на поръчки за продажби.
В този случай се създава неочаквано голям закръгляване запис.
Решение
Информация за актуалната корекция
Вече се предлага от Microsoft предоставя поддържана актуална корекция. Обаче е предназначена само за коригиране на описания в тази статия. Прилагайте корекцията само към системи, изпитващи този конкретен проблем. Възможно е провеждането на допълнителни тестове на тази актуална корекция. Следователно ако не сте силно засегнати от този проблем, препоръчваме да изчакате следващия сервизен пакет за Microsoft Dynamics NAV 2009 или следващата версия на Microsoft Dynamics NAV, който ще съдържа тази корекция.
Забележка: При специални случаи таксите, които са за свързани с поддръжката обаждания могат да бъдат отменени, ако специалист по техническа поддръжка за Microsoft Dynamics и свързани с тях продукти определя, че конкретна актуализация може да разреши проблема. Обичайните такси за поддръжката ще важат за допълнителни въпроси и проблеми, които не спадат към съответната актуализация.
Информация за инсталирането
Microsoft предоставя примери само за илюстративни цели без гаранция за определени цели. Това включва, но не е ограничено до, подразбиращи се гаранции за продаваемост или годност за определена цел. Тази статия се предполага, че сте запознати с демонстрирания език за програмиране и инструментите, които се използват за създаване и процедури за отстраняване на грешки. Инженерите на поддръжката на Microsoft могат да помогнат с обяснение на функциите на конкретна процедура, но няма да могат да модифицират тези примери с цел осигуряване на допълнителна функционалност или създаване на процедури за удовлетворение на конкретните ви изисквания.
Забележка: Преди да инсталирате тази актуална корекция, уверете се, че всички потребители на Microsoft Navision клиент излезли системата. Това включва Microsoft Navision Application услуги (NAS) клиент потребители. Трябва да бъде само клиент потребител, който е влязъл при прилагане на тази актуална корекция.
За прилагане на тази актуална корекция, трябва да имате лиценз разработчик.
Препоръчително е потребителският акаунт в прозореца влизания в Windows или в прозореца на БД присвояването на "СУПЕР" ИД на роля. Ако потребителският акаунт не може да бъде възложена ИД на роля на "СУПЕР", трябва да проверите, че потребителският акаунт има следните права:
-
Разрешение за промяна на обекта, ще се променя.
-
Разрешението за изпълнение за системата обект номер 5210 обект и системата обект ID 9015 обект.
Забележка: Не трябва да имате права на съхранените данни, освен ако трябва да извършите възстановяване на данни.
Промени код
Забележка: Винаги тест код решава в управлявана среда преди да приложите корекциите производство компютри.
За да разрешите този проблем, изпълнете следните стъпки:
-
Променете кода в CalcRndDiffAmt функция в "Продажби-Post" кодова единица (80) както следва:
Съществуващ код...// Delete the following lines.
PROCEDURE CalcRndDiffAmt@1360025(InvAmt@1360007 : Decimal;Currency@1360000 : Record 4) : Decimal;
BEGIN
EXIT(CalcTotalAmtInclVAT(Currency) - (InvAmt + CalcPostedAmtInclVAT));
// End of the lines.
END;
...Замени код
...// Add the following lines.
LOCAL PROCEDURE CalcRndDiffAmt@1360025(InvAmt@1360007 : Decimal;Currency@1360000 : Record 4) : Decimal;
VAR
TotalAmtInclVAT@1360001 : Decimal;
BEGIN
TotalAmtInclVAT :=
CalcTotalAmtInclVAT(Currency);
IF TotalAmtInclVAT = InvAmt THEN
EXIT(0);
EXIT(TotalAmtInclVAT - (InvAmt + CalcPostedAmtInclVAT));
// End of the lines.
END;
... -
Променете кода в IsFinalInvoice функция в "Продажби-Post" кодова единица (80) както следва:
Съществуващ код...SETRANGE("Document No.",SalesHeader."No.");
// Delete the following line.
EXIT(SalesPostAdvances.FullyDeductedCustPrepmt(SalesOrderLine));
END;
...Замени код
...SETRANGE("Document No.",SalesHeader."No.");
// Add the following line.
EXIT(SalesPostAdvances.IsFinalCustInvoice(SalesOrderLine));
END;
... -
Променете кода в CalcRndDiffAmt функция в кодова единица "Покупки-Post" (90) както следва:
Съществуващ код...// Delete the following lines.
PROCEDURE CalcRndDiffAmt@1360025(InvAmt@1360007 : Decimal;Currency@1360000 : Record 4) : Decimal;
BEGIN
EXIT(CalcTotalAmtInclVAT(Currency) - (InvAmt - CalcPostedAmtInclVAT));
// End of the lines.
END;
...Замени код
...// Add the following lines.
LOCAL PROCEDURE CalcRndDiffAmt@1360025(InvAmt@1360007 : Decimal;Currency@1360000 : Record 4) : Decimal;
VAR
TotalAmtInclVAT@1360001 : Decimal;
BEGIN
TotalAmtInclVAT :=
CalcTotalAmtInclVAT(Currency);
IF TotalAmtInclVAT = InvAmt THEN
EXIT(0);
EXIT(TotalAmtInclVAT - (InvAmt - CalcPostedAmtInclVAT));
// End of the lines.
END;
... -
Променете кода в IsFinalInvoice функция в кодова единица "Покупки-Post" (90) както следва:
Съществуващ код...SETRANGE("Document No.",PurchHeader."No.");
// Delete the following line.
EXIT(PurchPostAdvances.FullyDeductedVendPrepmt(PurchOrderLine));
END;
...Замени код
...SETRANGE("Document No.",PurchHeader."No.");
// Add the following line.
EXIT(PurchPostAdvances.IsFinalVendInvoice(PurchOrderLine));
END;
... -
Променете кода в SalesOrderProcessing функция в "Продажби-Post напредъка" кодова единица (26585) както следва:
Съществуващ код 1...VAR
// Delete the following lines.
FullyDeducted@1360007 : Boolean;
DocNoForVATCorr@1360006 : Code[20];
BEGIN
WITH SalesHeader DO BEGIN
FullyDeducted := FullyDeductedCustPrepmt(SalesLine);
IF FullyDeducted THEN
// End of the lines.
InvoicedAmount :=
...Замени код 1
...VAR
// Add the following lines.
IsFinalInvoice@1360007 : Boolean;
DocNoForVATCorr@1360006 : Code[20];
BEGIN
WITH SalesHeader DO BEGIN
IsFinalInvoice := IsFinalCustInvoice(SalesLine);
IF IsFinalInvoice THEN
// End of the lines.
InvoicedAmount :=
...Съществуващ код 2
...SalesLine,SalesInvHeader,LinkedAdvanceEntry,DocNoForVATCorr,
// Delete the following line.
FullyDeducted,TempJnlLineDim,InvoicedAmount,Post);
UNTIL SalesLine.NEXT = 0;
...Замени код 2
...SalesLine,SalesInvHeader,LinkedAdvanceEntry,DocNoForVATCorr,
// Add the following line.
IsFinalInvoice,TempJnlLineDim,InvoicedAmount,Post);
UNTIL SalesLine.NEXT = 0;
... -
Променете кода в FullyDeductedCustPrepmt функция в "Продажби-Post напредъка" кодова единица (26585) както следва:
Съществуващ код 1...// Delete the following line.
PROCEDURE FullyDeductedCustPrepmt@1470047(VAR SalesLine@1470000 : Record 37) : Boolean;
BEGIN
...Замени код 1
...// Add the following line.
PROCEDURE IsFinalCustInvoice@1470047(VAR SalesLine@1470000 : Record 37) : Boolean;
BEGIN
...Съществуващ код 2
...SetSalesLineToPost(SalesLine);
// Delete the following line.
IF SalesLine."Prepmt Amt to Deduct" + SalesLine."Prepmt Amt Deducted" <> SalesLine."Prepmt. Amt. Inv." THEN
EXIT(FALSE);
...Замени код 2
...SetSalesLineToPost(SalesLine);
// Add the following line.
IF SalesLine."Qty. to Invoice" + SalesLine."Quantity Invoiced" <> SalesLine.Quantity THEN
EXIT(FALSE);
... -
Променете кода в CollectFullyDeductedOrders функция в "Продажби-Post напредъка" кодова единица (26858) както следва:
Съществуващ код 1...TempSalesOrderLine@1360003 : TEMPORARY Record 37;
// Delete the following line.
FullyDeducted@1360004 : Boolean;
BEGIN
...Замени код 1
...TempSalesOrderLine@1360003 : TEMPORARY Record 37;
// Add the following line.
IsFinalInvoice@1360004 : Boolean;
BEGIN
...Съществуващ код 2
...FilterSalesOrderLineWithHeader(SalesOrderLine,FullyDeductedOrder);
// Delete the following lines.
FullyDeducted := FullyDeductedOrder.FIND;
IF NOT FullyDeducted THEN BEGIN
FullyDeducted := FullyDeductedCustPrepmt(SalesOrderLine);
IF FullyDeducted THEN
FullyDeductedOrder.INSERT;
END;
IF FullyDeducted THEN BEGIN
// End of the lines.
FillSalesOrderLineFromSalesInv(TempSalesOrderLine,SalesOrderLine);
...Замени код 2
...FilterSalesOrderLineWithHeader(SalesOrderLine,FullyDeductedOrder);
// Add the following lines.
IsFinalInvoice := FullyDeductedOrder.FIND;
IF NOT IsFinalInvoice THEN BEGIN
IsFinalInvoice := IsFinalCustInvoice(SalesOrderLine);
IF IsFinalInvoice THEN
FullyDeductedOrder.INSERT;
END;
IF IsFinalInvoice THEN BEGIN
// End of the lines.
FillSalesOrderLineFromSalesInv(TempSalesOrderLine,SalesOrderLine);
... -
Променете кода в PurchOrderProcessing функция в "Purchace Post напредъка" кодова единица (26586) както следва:
Съществуващ код 1...VAR
// Delete the following lines.
FullyDeducted@1360007 : Boolean;
DocNoForVATCorr@1360006 : Code[20];
BEGIN
WITH PurchHeader DO BEGIN
FullyDeducted := FullyDeductedVendPrepmt(PurchLine);
IF FullyDeducted THEN
// End of the lines.
InvoicedAmount :=
...Замени код 1
...VAR
// Add the following lines.
IsFinalInvoice@1360007 : Boolean;
DocNoForVATCorr@1360006 : Code[20];
BEGIN
WITH PurchHeader DO BEGIN
IsFinalInvoice := IsFinalVendInvoice(PurchLine);
IF IsFinalInvoice THEN
// End of the lines.
InvoicedAmount :=
...Съществуващ код 2
...PurchLine,PurchInvHeader,LinkedAdvanceEntry,DocNoForVATCorr,
// Delete the following line.
FullyDeducted,TempJnlLineDim,InvoicedAmount,Post);
UNTIL PurchLine.NEXT = 0;
...Замени код 2
...PurchLine,PurchInvHeader,LinkedAdvanceEntry,DocNoForVATCorr,
// Add the following line.
IsFinalInvoice,TempJnlLineDim,InvoicedAmount,Post);
UNTIL PurchLine.NEXT = 0;
... -
Променете кода в FullyDeductedVendPrepmt функция в "Purchace Post напредъка" кодова единица (26586) както следва:
Съществуващ код 1...// Delete the following line.
PROCEDURE FullyDeductedVendPrepmt@1470047(VAR PurchLine@1470000 : Record 39) : Boolean;
BEGIN
...Замени код 1
...// Add the following line.
PROCEDURE IsFinalVendInvoice@1470047(VAR PurchLine@1470000 : Record 39) : Boolean;
BEGIN
...Съществуващ код 2
...SetPurchLineToPost(PurchLine);
// Delete the following line.
IF PurchLine."Prepmt Amt to Deduct" + PurchLine."Prepmt Amt Deducted" <> PurchLine."Prepmt. Amt. Inv." THEN
EXIT(FALSE);
...Замени код 2
...SetPurchLineToPost(PurchLine);
// Add the following line.
IF PurchLine."Qty. to Invoice" + PurchLine."Quantity Invoiced" <> PurchLine.Quantity THEN
EXIT(FALSE);
... -
Променете кода в CollectFullyDeductedOrders функция в "Purchace Post напредъка" кодова единица (26586) както следва:
Съществуващ код 1...TempPurchOrderLine@1360003 : TEMPORARY Record 39;
// Delete the following line.
FullyDeducted@1360004 : Boolean;
BEGIN
...Замени код 1
...TempPurchOrderLine@1360003 : TEMPORARY Record 39;
// Add the following line.
IsFinalInvoice@1360004 : Boolean;
BEGIN
...Съществуващ код 2
...FilterPurchOrderLineWithHeader(PurchOrderLine,FullyDeductedOrder);
// Delete the following lines.
FullyDeducted := FullyDeductedOrder.FIND;
IF NOT FullyDeducted THEN BEGIN
FullyDeducted := FullyDeductedVendPrepmt(PurchOrderLine);
IF FullyDeducted THEN
FullyDeductedOrder.INSERT;
END;
IF FullyDeducted THEN BEGIN
// End of the lines.
FillPurchOrderLineFromPurchInv(TempPurchOrderLine,PurchOrderLine);
...Замени код 2
...FilterPurchOrderLineWithHeader(PurchOrderLine,FullyDeductedOrder);
// Add the following lines.
IsFinalInvoice := FullyDeductedOrder.FIND;
IF NOT IsFinalInvoice THEN BEGIN
IsFinalInvoice := IsFinalVendInvoice(PurchOrderLine);
IF IsFinalInvoice THEN
FullyDeductedOrder.INSERT;
END;
IF IsFinalInvoice THEN BEGIN
// End of the lines.
FillPurchOrderLineFromPurchInv(TempPurchOrderLine,PurchOrderLine);
...
Необходими условия:
Трябва да имате унгарски версия на Microsoft Dynamics NAV 2009 R2 с актуализацията на авансови плащания, за да приложите тази актуална корекция.
Информация за премахване
Не можете да премахнете тази актуална корекция.
Статус
Microsoft потвърждава, че това е проблем в продуктите на Microsoft, изброени в раздела "Отнася се за".
Забележка: Това е статия "БЪРЗА ПУБЛИКАЦИЯ", създадени директно от организацията за поддръжка на Microsoft. Информацията тук се предоставя "както-е" в отговор на появили се проблеми. В резултат на скоростта на предоставянето му материалите могат да съдържат печатни грешки и могат да бъдат коригирани по всяко време без предизвестие. Вижте Условия за други съображения.