Симптоми
Общият размер на напомняне е наред, ако акаунтът напомняне такса с ДДС (ДДС) в Microsoft Dynamics NAV 2009. Това се случва, въпреки че не е регистриран напомняне такса и клиентът е клиент на ЕС. Следвайте стъпките в раздела промени код за решаване на проблема. Този проблем възниква в следните продукти:
-
Microsoft Dynamics NAV 2009 R2
-
Microsoft Dynamics NAV 2009 SP1
Решение
Информация за актуалната корекция
Вече се предлага от Microsoft предоставя поддържана актуална корекция. Обаче е предназначена само за коригиране на описания в тази статия. Прилагайте корекцията само към системи, изпитващи този конкретен проблем. Възможно е провеждането на допълнителни тестове на тази актуална корекция. Следователно ако не сте силно засегнати от този проблем, препоръчваме да изчакате следващия сервизен пакет за Microsoft Dynamics NAV 2009 или следващата версия на Microsoft Dynamics NAV, който ще съдържа тази корекция.
Забележка: При специални случаи таксите, които са за свързани с поддръжката обаждания могат да бъдат отменени, ако специалист по техническа поддръжка за Microsoft Dynamics и свързани с тях продукти определя, че конкретна актуализация може да разреши проблема. Обичайните такси за поддръжката ще важат за допълнителни въпроси и проблеми, които не спадат към съответната актуализация.
Информация за инсталирането
Microsoft предоставя примери само за илюстративни цели без гаранция за определени цели. Това включва, но не е ограничено до, подразбиращи се гаранции за продаваемост или годност за определена цел. Тази статия се предполага, че сте запознати с демонстрирания език за програмиране и инструментите, които се използват за създаване и процедури за отстраняване на грешки. Инженерите на поддръжката на Microsoft могат да помогнат обяснение на функциите на конкретна процедура. Въпреки това те няма да модифицират тези примери с цел осигуряване на допълнителна функционалност или създаване на процедури за удовлетворение на конкретните ви изисквания.
Забележка: Преди да инсталирате тази актуална корекция, уверете се, че всички потребители на клиента на Microsoft Dynamics NAV са излезли от системата. Това включва и услуги на Microsoft Dynamics NAV приложение сървър (NAS). Трябва да бъде само клиент потребител, който е влязъл при прилагане на тази актуална корекция.
За прилагане на тази актуална корекция, трябва да имате лиценз разработчик.
Препоръчително е потребителският акаунт в прозореца влизания в Windows или в прозореца на БД присвояването на "Супер" ИД на роля. Ако потребителският акаунт не може да бъде възложена ИД на роля на "Супер", трябва да проверите, че потребителският акаунт има следните права:
-
Разрешение за промяна на обекта, ще се променя.
-
Разрешението за изпълнение за системата обект номер 5210 обект и системата обект ID 9015
обект.
Забележка: Не трябва да имате права на съхранените данни, освен ако трябва да извършите възстановяване на данни.
Промени код
Забележка: Винаги тест код решава в управлявана среда преди да приложите корекциите производство компютри.
За да разрешите този проблем, изпълнете следните стъпки:
-
Променяте свойствата във формуляра напомняне статистика (437) както следва:
Съществуващ код... CALCFIELDS("Interest Amount","VAT Amount");
ReminderTotal := "Remaining Amount" + "Additional Fee" + "Interest Amount" + "VAT Amount";
CustPostingGr.GET("Customer Posting Group");
VATInterest := 0;
IF ReminderLevel.GET("Reminder Terms Code","Reminder Level") THEN
// Delete the following lines.
IF ReminderLevel."Calculate Interest" THEN BEGIN
GLAcc.GET(CustPostingGr."Interest Account");
VATPostingSetup.GET("VAT Bus. Posting Group",GLAcc."VAT Prod. Posting Group");
VATInterest := VATPostingSetup."VAT %";
END;
IF GLAcc.GET(CustPostingGr."Additional Fee Account") THEN
VATPostingSetup.GET("VAT Bus. Posting Group",GLAcc."VAT Prod. Posting Group");
Interest := (ReminderTotal - "Remaining Amount" - "Additional Fee" * (VATPostingSetup."VAT %"/100 + 1))/
(VATInterest/100 + 1);
VatAmount := Interest * VATInterest/100 +
"Additional Fee" * VATPostingSetup."VAT %"/100;
// End of the deleted lines.
IF Cust.GET("Customer No.") THEN
Cust.CALCFIELDS("Balance (LCY)")
ELSE
CLEAR(Cust);
IF Cust."Credit Limit (LCY)" = 0 THEN
...Замени код
... CALCFIELDS("Interest Amount","VAT Amount");
ReminderTotal := "Remaining Amount" + "Additional Fee" + "Interest Amount" + "VAT Amount";
CustPostingGr.GET("Customer Posting Group");
VATInterest := 0;
IF ReminderLevel.GET("Reminder Terms Code","Reminder Level") THEN
// Add the following lines.
IF ReminderLevel."Calculate Interest" AND ("VAT Amount" <> 0) THEN BEGIN
GLAcc.GET(CustPostingGr."Interest Account");
VATPostingSetup.GET("VAT Bus. Posting Group",GLAcc."VAT Prod. Posting Group");
VATInterest := VATPostingSetup."VAT %";
IF GLAcc.GET(CustPostingGr."Additional Fee Account") THEN
VATPostingSetup.GET("VAT Bus. Posting Group",GLAcc."VAT Prod. Posting Group");
Interest :=
(ReminderTotal -
"Remaining Amount" - "Additional Fee" * (VATPostingSetup."VAT %"/ 100 + 1)) /(VATInterest / 100 + 1);
VatAmount := Interest * VATInterest / 100 + "Additional Fee" * VATPostingSetup."VAT %" / 100;
END ELSE
Interest := "Interest Amount";
// End of the added lines.
IF Cust.GET("Customer No.") THEN
Cust.CALCFIELDS("Balance (LCY)")
ELSE
CLEAR(Cust);
IF Cust."Credit Limit (LCY)" = 0 THEN
... -
Променяте свойствата във формуляра напомняне статистика (441) както следва:
Съществуващ код...BEGIN
SETRANGE("No.");
CALCFIELDS("Interest Amount","VAT Amount");
ReminderTotal := "Remaining Amount" + "Additional Fee" + "Interest Amount" + "VAT Amount";
CustPostingGr.GET("Customer Posting Group");
// Delete the following lines.
ReminderLevel.GET("Reminder Terms Code","Reminder Level");
IF ReminderLevel."Calculate Interest" THEN BEGIN
GLAcc.GET(CustPostingGr."Interest Account");
VATPostingSetup.GET("VAT Bus. Posting Group",GLAcc."VAT Prod. Posting Group");
VATInterest := VATPostingSetup."VAT %";
END ELSE
VATInterest := 0;
IF GLAcc.GET(CustPostingGr."Additional Fee Account") THEN
VATPostingSetup.GET("VAT Bus. Posting Group",GLAcc."VAT Prod. Posting Group");
Interest := (ReminderTotal - "Remaining Amount" - "Additional Fee" * (VATPostingSetup."VAT %"/100 + 1))/
(VATInterest/100 + 1);
VatAmount := Interest * VATInterest/100 +
"Additional Fee" * VATPostingSetup."VAT %"/100;
// End of the deleted lines.
IF Cust.GET("Customer No.") THEN
Cust.CALCFIELDS("Balance (LCY)")
ELSE
CLEAR(Cust);
IF Cust."Credit Limit (LCY)" = 0 THEN
...Замени код
...BEGIN
SETRANGE("No.");
CALCFIELDS("Interest Amount","VAT Amount");
ReminderTotal := "Remaining Amount" + "Additional Fee" + "Interest Amount" + "VAT Amount";
CustPostingGr.GET("Customer Posting Group");
// Add the following lines.
IF ReminderLevel.GET("Reminder Terms Code","Reminder Level") THEN
IF ReminderLevel."Calculate Interest" AND ("VAT Amount" <> 0) THEN BEGIN
GLAcc.GET(CustPostingGr."Interest Account");
VATPostingSetup.GET("VAT Bus. Posting Group",GLAcc."VAT Prod. Posting Group");
VATInterest := VATPostingSetup."VAT %";
IF GLAcc.GET(CustPostingGr."Additional Fee Account") THEN
VATPostingSetup.GET("VAT Bus. Posting Group",GLAcc."VAT Prod. Posting Group");
Interest :=
(ReminderTotal -
"Remaining Amount" - "Additional Fee" * (VATPostingSetup."VAT %"/ 100 + 1)) /(VATInterest / 100 + 1);
VatAmount := Interest * VATInterest / 100 + "Additional Fee" * VATPostingSetup."VAT %" / 100;
END ELSE
Interest := "Interest Amount";
// End of the added lines.
IF Cust.GET("Customer No.") THEN
Cust.CALCFIELDS("Balance (LCY)")
ELSE
CLEAR(Cust);
IF Cust."Credit Limit (LCY)" = 0 THEN
... -
Да променяте данни елемент номер 1 в напомняне статистически отчети (117) както следва:
Съществуващ код...IF GLAcc.GET(CustPostingGroup."Additional Fee Account") THEN BEGIN
VATPostingSetup.GET("VAT Bus. Posting Group",GLAcc."VAT Prod. Posting Group");
AddFeeInclVAT := "Additional Fee" * (1 + VATPostingSetup."VAT %"/100);
END ELSE
AddFeeInclVAT := "Additional Fee";
// Delete the following lines.
CALCFIELDS("Interest Amount");
IF "Interest Amount" <> 0 THEN BEGIN
GLAcc.GET(CustPostingGroup."Interest Account");
VATPostingSetup.GET("VAT Bus. Posting Group",GLAcc."VAT Prod. Posting Group");
VATInterest := VATPostingSetup."VAT %";
END ELSE
VATInterest := 0;
// End of the deleted lines.
IF ISSERVICETIER THEN BEGIN
NNC_InterestAmountTotal := 0;
NNC_RemainingAmountTotal := 0;
NNC_VATAmountTotal := 0;
...Замени код
... IF GLAcc.GET(CustPostingGroup."Additional Fee Account") THEN BEGIN
VATPostingSetup.GET("VAT Bus. Posting Group",GLAcc."VAT Prod. Posting Group");
AddFeeInclVAT := "Additional Fee" * (1 + VATPostingSetup."VAT %"/100);
END ELSE
AddFeeInclVAT := "Additional Fee";
// Add the following lines.
CALCFIELDS("Interest Amount","VAT Amount");
IF ("Interest Amount" <> 0) AND ("VAT Amount" <> 0) THEN BEGIN
GLAcc.GET(CustPostingGroup."Interest Account");
VATPostingSetup.GET("VAT Bus. Posting Group",GLAcc."VAT Prod. Posting Group");
VATInterest := VATPostingSetup."VAT %";
Interest:=
(ReminderInterestAmount +
"VAT Amount" +"Issued Reminder Header"."Additional Fee" - AddFeeInclVAT) / (VATInterest / 100 + 1);
END ELSE BEGIN
Interest:= "Interest Amount";
VATInterest := 0;
END;
// End of the added lines.
IF ISSERVICETIER THEN BEGIN
NNC_InterestAmountTotal := 0;
NNC_RemainingAmountTotal := 0;
NNC_VATAmountTotal := 0;
... -
Да променяте данни елемент номер 4 секции в напомняне статистически отчети (117) както следва:
Съществуващ код 1...}
CONTROLS
{
{ 45 ;TextBox ;10710;0 ;2520 ;423 ;FontSize=9;
CaptionML=ENU=Interest Amount;
// Delete the following line.
SourceExpr=(ReminderInterestAmount + "VAT Amount" +"Issued Reminder Header"."Additional Fee" - AddFeeInclVAT)/(VATInterest/100 +1);
// End of the deleted line.
AutoFormatType=1;
AutoFormatExpr="Issued Reminder Line".GetCurrencyCodeFromHeader;
DataSetFieldName=ReminderInterestAmount____VAT_Amount____Issued_Reminder_Header___Additional_Fee____AddFeeInclVAT___VATInterest_100__1_ }
{ 47 ;Label ;6090 ;0 ;4200 ;423 ;ParentControl=45;
FontSize=9;
...Замени код 1
...}
CONTROLS
{
{ 45 ;TextBox ;10710;0 ;2520 ;423 ;FontSize=9;
CaptionML=ENU=Interest Amount;
// Add the following line.
SourceExpr=Interest;
// End of the added line.
AutoFormatType=1;
AutoFormatExpr="Issued Reminder Line".GetCurrencyCodeFromHeader;
DataSetFieldName=ReminderInterestAmount____VAT_Amount____Issued_Reminder_Header___Additional_Fee____AddFeeInclVAT___VATInterest_100__1_ }
{ 47 ;Label ;6090 ;0 ;4200 ;423 ;ParentControl=45;
FontSize=9;
...Съществуващ код 2
...CONTROLS
{
{ 44 ;TextBox ;10710;0 ;2520 ;423 ;FontSize=9;
FontBold=Yes;
CaptionML=ENU=Total;
// Delete the following line.
SourceExpr="Remaining Amount" + ReminderInterestAmount + "VAT Amount"-(ReminderInterestAmount + "VAT Amount" +"Issued Reminder Header"."Additional Fee" - AddFeeInclVAT)/(VATInterest/100+1)*VATInterest/100 + "Issued Reminder Header"."Additional Fee" - AddFeeInclVAT;
// End of the deleted line.
AutoFormatType=1;
AutoFormatExpr="Issued Reminder Line".GetCurrencyCodeFromHeader;
DataSetFieldName=Remaining_Amount____ReminderInterestAmount____VAT_Amount___ReminderInterestAmount____VAT_Amount____Issued_Reminder_Header___Additional_Fee____AddFeeInclVAT___VATInterest_100_1__VATInterest_100____Issued_Reminder_Header___Additional_Fee____AddFeeInclVAT }
{ 56 ;TextBox ;6090 ;0 ;4200 ;423 ;FontSize=9;
FontBold=Yes;
...Замени код 2
... CONTROLS
{
{ 44 ;TextBox ;10710;0 ;2520 ;423 ;FontSize=9;
FontBold=Yes;
CaptionML=ENU=Total;
// Add the following line.
SourceExpr="Remaining Amount" + ReminderInterestAmount;
// End of the added line.
AutoFormatType=1;
AutoFormatExpr="Issued Reminder Line".GetCurrencyCodeFromHeader;
DataSetFieldName=Remaining_Amount____ReminderInterestAmount____VAT_Amount___ReminderInterestAmount____VAT_Amount____Issued_Reminder_Header___Additional_Fee____AddFeeInclVAT___VATInterest_100_1__VATInterest_100____Issued_Reminder_Header___Additional_Fee____AddFeeInclVAT }
{ 56 ;TextBox ;6090 ;0 ;4200 ;423 ;FontSize=9;
FontBold=Yes;
... -
Да променяте данни елемент номер 1 в напомняне статистически отчети (122) както следва:
Съществуващ код...IF GLAcc.GET(CustPostingGroup."Additional Fee Account") THEN BEGIN
VATPostingSetup.GET("VAT Bus. Posting Group",GLAcc."VAT Prod. Posting Group");
AddFeeInclVAT := "Additional Fee" * (1 + VATPostingSetup."VAT %"/100);
END ELSE
AddFeeInclVAT := "Additional Fee";
// Delete the following lines.
CALCFIELDS("Interest Amount");
IF "Interest Amount" <> 0 THEN BEGIN
GLAcc.GET(CustPostingGroup."Interest Account");
VATPostingSetup.GET("VAT Bus. Posting Group",GLAcc."VAT Prod. Posting Group");
VATInterest := VATPostingSetup."VAT %";
END ELSE
VATInterest := 0;
// End of the deleted lines.
IF ISSERVICETIER THEN BEGIN
NNC_Interest := 0;
NNC_TotalLCY := 0;
NNC_VATAmount := 0;
NNC_TotalLCYVATAmount := 0;
...Замени код
...IF GLAcc.GET(CustPostingGroup."Additional Fee Account") THEN BEGIN
VATPostingSetup.GET("VAT Bus. Posting Group",GLAcc."VAT Prod. Posting Group");
AddFeeInclVAT := "Additional Fee" * (1 + VATPostingSetup."VAT %"/100);
END ELSE
AddFeeInclVAT := "Additional Fee";
// Add the following lines.
CALCFIELDS("Interest Amount","VAT Amount");
IF ("Interest Amount" <> 0) AND ("VAT Amount" <> 0) THEN BEGIN
GLAcc.GET(CustPostingGroup."Interest Account");
VATPostingSetup.GET("VAT Bus. Posting Group",GLAcc."VAT Prod. Posting Group");
VATInterest := VATPostingSetup."VAT %";
Interest:=
(ReminderInterestAmount +
"VAT Amount" +"Reminder Header"."Additional Fee" - AddFeeInclVAT) / (VATInterest / 100 + 1);
END ELSE BEGIN
Interest:= "Interest Amount";
VATInterest := 0;
END;
IF VATInterest <> 0 THEN
// End of the added lines.
IF ISSERVICETIER THEN BEGIN
NNC_Interest := 0;
NNC_TotalLCY := 0;
NNC_VATAmount := 0;
NNC_TotalLCYVATAmount := 0;
... -
Да променяте данни елемент номер 2 в напомняне статистически отчети (122) както следва:
Съществуващ код... }
{ PROPERTIES
{
DataItemIndent=1;
DataItemTable=Table2000000026;
// Delete the following line.
DataItemTableView=SORTING(Number) WHERE(Number=CONST(1));
// End of the deleted line.
DataItemVarName=PageCounter;
}
SECTIONS
{
{ PROPERTIES
...Замени код
...}
{ PROPERTIES
{
DataItemIndent=1;
DataItemTable=Table2000000026;
// Add the following lines.
DataItemTableView=SORTING(Number)
WHERE(Number=CONST(1));
// End of the added lines.
DataItemVarName=PageCounter;
}
SECTIONS
{
{ PROPERTIES
... -
Да променяте данни елемент номер 3 в напомняне статистически отчети (122) както следва:
Съществуващ код...}
{ PROPERTIES
{
DataItemIndent=2;
DataItemTable=Table2000000026;
// Delete the following line.
DataItemTableView=SORTING(Number) WHERE(Number=FILTER(1..));
// End of the deleted line.
DataItemVarName=DimensionLoop;
OnPreDataItem=BEGIN
IF NOT ShowDim THEN
CurrReport.BREAK;
DocDim.SETRANGE("Table ID",DATABASE::"Reminder Header");
...Замени код
...}
{ PROPERTIES
{
DataItemIndent=2;
DataItemTable=Table2000000026;
// Add the following lines.
DataItemTableView=SORTING(Number)
WHERE(Number=FILTER(1..));
// End of the added lines.
DataItemVarName=DimensionLoop;
OnPreDataItem=BEGIN
IF NOT ShowDim THEN
CurrReport.BREAK;
DocDim.SETRANGE("Table ID",DATABASE::"Reminder Header");
... -
В промени на данни елемент номер 5 в напомняне статистически отчети (122) както следва:
Съществуващ код... }
{ PROPERTIES
{
DataItemIndent=2;
DataItemTable=Table296;
// Delete the following line.
DataItemTableView=SORTING(Reminder No.,Line No.) WHERE(Line Type=FILTER(<>Not Due));
// End of the deleted line.
OnPreDataItem=BEGIN
IF ISSERVICETIER THEN
TotalVATAmount := 0;
IF FIND('+') THEN BEGIN
...Замени код
...}
{ PROPERTIES
{
DataItemIndent=2;
DataItemTable=Table296;
// Add the following lines.
DataItemTableView=SORTING(Reminder No.,Line No.)
WHERE(Line Type=FILTER(<>Not Due));
// End of the added lines.
OnPreDataItem=BEGIN
IF ISSERVICETIER THEN
TotalVATAmount := 0;
IF FIND('+') THEN BEGIN
... -
Променяте в разделите данни елемент номер 5 в напомняне статистически отчети (122) както следва:
Съществуващ код 1... }
CONTROLS
{
{ 17 ;TextBox ;10710;0 ;2520 ;423 ;FontSize=9;
CaptionML=ENU=Interest Amount;
// Delete the following line.
SourceExpr=(ReminderInterestAmount + "VAT Amount" +"Reminder Header"."Additional Fee" - AddFeeInclVAT)/(VATInterest/100 +1);
// End of the deleted line.
AutoFormatType=1;
AutoFormatExpr="Reminder Line".GetCurrencyCodeFromHeader;
DataSetFieldName=ReminderInterestAmount____VAT_Amount____Reminder_Header___Additional_Fee____AddFeeInclVAT___VATInterest_100__1_ }
{ 20 ;Label ;6090 ;0 ;4200 ;423 ;ParentControl=17;
FontSize=9;
...Замени код 1
... }
CONTROLS
{
{ 17 ;TextBox ;10710;0 ;2520 ;423 ;FontSize=9;
CaptionML=ENU=Interest Amount;
// Add the following line.
SourceExpr=Interest;
// End of the added line.
AutoFormatType=1;
AutoFormatExpr="Reminder Line".GetCurrencyCodeFromHeader;
DataSetFieldName=ReminderInterestAmount____VAT_Amount____Reminder_Header___Additional_Fee____AddFeeInclVAT___VATInterest_100__1_ }
{ 20 ;Label ;6090 ;0 ;4200 ;423 ;ParentControl=17;
FontSize=9;
...Съществуващ код 2
...}
CONTROLS
{
{ 29 ;TextBox ;10710;0 ;2520 ;423 ;FontSize=9;
FontBold=Yes;
// Delete the following line.
SourceExpr="Remaining Amount" + ReminderInterestAmount + "VAT Amount"-(ReminderInterestAmount + "VAT Amount" +"Reminder Header"."Additional Fee" - AddFeeInclVAT)/(VATInterest/100+1)*VATInterest/100 + "Reminder Header"."Additional Fee" - AddFeeInclVAT;
// End of the deleted line.
AutoFormatType=1;
AutoFormatExpr="Reminder Line".GetCurrencyCodeFromHeader;
DataSetFieldName=Remaining_Amount____ReminderInterestAmount____VAT_Amount___ReminderInterestAmount____VAT_Amount____Reminder_Header___Additional_Fee____AddFeeInclVAT___VATInterest_100_1__VATInterest_100____Reminder_Header___Additional_Fee____AddFeeInclVAT }
{ 43 ;TextBox ;6090 ;0 ;4200 ;423 ;FontSize=9;
FontBold=Yes;
...Замени код 2
...}
CONTROLS
{
{ 29 ;TextBox ;10710;0 ;2520 ;423 ;FontSize=9;
FontBold=Yes;
// Add the following line.
SourceExpr="Remaining Amount" + ReminderInterestAmount;
// End of the added line.
AutoFormatType=1;
AutoFormatExpr="Reminder Line".GetCurrencyCodeFromHeader;
DataSetFieldName=Remaining_Amount____ReminderInterestAmount____VAT_Amount___ReminderInterestAmount____VAT_Amount____Reminder_Header___Additional_Fee____AddFeeInclVAT___VATInterest_100_1__VATInterest_100____Reminder_Header___Additional_Fee____AddFeeInclVAT }
{ 43 ;TextBox ;6090 ;0 ;4200 ;423 ;FontSize=9;
FontBold=Yes;
...
Необходими условия:
Трябва да имате един от следните продукти, за да приложите тази спешна корекция:
-
Microsoft Dynamics NAV 2009 R2
-
Microsoft Dynamics NAV 2009 SP1
Информация за премахване
Не можете да премахнете тази актуална корекция.
Статус
Microsoft потвърждава, че това е проблем в продуктите на Microsoft, изброени в раздела "Отнася се за".
Забележка: Това е статия "Бърза публикация", създадени директно от организацията за поддръжка на Microsoft. Информацията тук се предоставя "както-е" в отговор на появили се проблеми. В резултат на скоростта на предоставянето му материалите могат да съдържат печатни грешки и могат да бъдат коригирани по всяко време без предизвестие. Вижте Условияза други съображения.