Преминаване към основното съдържание
Поддръжка
Влизане с Microsoft
Влезте или създайте акаунт.
Здравейте,
Изберете друг акаунт.
Имате няколко акаунта
Изберете акаунта, с който искате да влезете.

В тази статия се отнася за Microsoft Dynamics NAV за всички държави и всички езикови местоположения.

Симптоми

Да предположим, че добавяте такса за покупка документ в Microsoft Dynamics NAV 2009. След това можете да променяте ДДС покупки статистически формуляр или страница. Когато отворите формуляра статистика или страница отново, стойността се изчислява повторно.

Този проблем възниква в следните продукти:

  • Microsoft Dynamics NAV 2009 Service Pack 1 (SP1)

  • Microsoft Dynamics NAV 2009 R2

Решение

Информация за актуалната корекция

Вече се предлага от Microsoft предоставя поддържана актуална корекция. Обаче е предназначена само за коригиране на описания в тази статия. Прилагайте корекцията само към системи, изпитващи този конкретен проблем. Възможно е провеждането на допълнителни тестове на тази актуална корекция. Следователно ако не сте силно засегнати от този проблем, препоръчваме да изчакате следващия сервизен пакет за Microsoft Dynamics NAV 2009 или следващата версия на Microsoft Dynamics NAV, който ще съдържа тази корекция.

Забележка: При специални случаи таксите, които се начисляват за свързани с поддръжката обаждания могат да бъдат отменени, ако специалист по техническа поддръжка за Microsoft Dynamics и свързани с тях продукти определя, че конкретна актуализация може да разреши проблема. Обичайните такси за поддръжката ще важат за допълнителни въпроси и проблеми, които не спадат към съответната актуализация.



Информация за инсталирането

Microsoft предоставя примери само за илюстративни цели без гаранция за определени цели. Това включва, но не е ограничено до, подразбиращи се гаранции за продаваемост или годност за определена цел. Тази статия се предполага, че сте запознати с демонстрирания език за програмиране и инструментите, които се използват за създаване и процедури за отстраняване на грешки. Инженерите на поддръжката на Microsoft могат да помогнат с обяснение на функциите на конкретна процедура, но няма да могат да модифицират тези примери с цел осигуряване на допълнителна функционалност или създаване на процедури за удовлетворение на конкретните ви изисквания.

Забележка: Преди да инсталирате тази актуална корекция, уверете се, че всички потребители на Microsoft Navision клиент излезли системата. Това включва Microsoft Navision Application услуги (NAS) клиент потребители. Трябва да бъде само клиент потребител, който е влязъл при прилагане на тази актуална корекция.

За прилагане на тази актуална корекция, трябва да имате лиценз разработчик.

Препоръчително е потребителският акаунт в прозореца влизания в Windows или в прозореца на БД присвояването на "Супер" ИД на роля. Ако потребителският акаунт не може да бъде възложена ИД на роля на "Супер", трябва да проверите, че потребителският акаунт има следните права:

  • Разрешение за промяна на обекта, ще се променя.

  • Разрешението за изпълнение за системата обект номер 5210 обект и системата обект ID 9015 обект.


Забележка: Не трябва да имате права на съхранените данни, освен ако трябва да извършите възстановяване на данни.

Промени код

Забележка: Винаги тест код решава в управлявана среда преди да приложите корекциите производство компютри.
За да разрешите този проблем, изпълнете следните стъпки:

  1. Промяна на кода на UpdateVATAmounts функцията в таблицата ред в продажби (37) както следва:
    Съществуващ код 1

    ...END;

    LOCAL PROCEDURE UpdateVATAmounts@38();
    VAR
    SalesLine2@1000 : Record 37;
    TotalLineAmount@1005 : Decimal;
    TotalInvDiscAmount@1004 : Decimal;
    TotalAmount@1001 : Decimal;
    TotalAmountInclVAT@1002 : Decimal;
    TotalQuantityBase@1003 : Decimal;
    ...

    Замени код 1

    ...END;

    LOCAL PROCEDURE UpdateVATAmounts@38();
    VAR
    SalesLine2@1000 : Record 37;

    // Add the following line.
    CustPostingGr@1009 : Record 92;
    // End of the added line.

    TotalLineAmount@1005 : Decimal;
    TotalInvDiscAmount@1004 : Decimal;
    TotalAmount@1001 : Decimal;
    TotalAmountInclVAT@1002 : Decimal;
    TotalQuantityBase@1003 : Decimal;
    ...

    Съществуващ код 2

    ...SalesLine2.SETFILTER(Amount,'>%1',0)
    ELSE
    SalesLine2.SETFILTER(Amount,'<%1',0);
    SalesLine2.SETRANGE("VAT Identifier","VAT Identifier");
    SalesLine2.SETRANGE("Tax Group Code","Tax Group Code");

    IF "Line Amount" = "Inv. Discount Amount" THEN BEGIN
    Amount := 0;
    "VAT Base Amount" := 0;
    "Amount Including VAT" := 0;
    ...

    Замени код 2

    ...SalesLine2.SETFILTER(Amount,'>%1',0)
    ELSE
    SalesLine2.SETFILTER(Amount,'<%1',0);
    SalesLine2.SETRANGE("VAT Identifier","VAT Identifier");
    SalesLine2.SETRANGE("Tax Group Code","Tax Group Code");

    // Add the following line.
    CustPostingGr.GET(SalesHeader."Customer Posting Group");
    // End of the added line.

    IF "Line Amount" = "Inv. Discount Amount" THEN BEGIN
    Amount := 0;
    "VAT Base Amount" := 0;
    "Amount Including VAT" := 0;
    ...

    Съществуващ код 3

    ...IF "Line Amount" = "Inv. Discount Amount" THEN BEGIN
    Amount := 0;
    "VAT Base Amount" := 0;
    "Amount Including VAT" := 0;

    // Delete the following line.
    IF "Line No." <> 0 THEN
    // End of the deleted line.

    IF MODIFY THEN
    IF SalesLine2.FINDLAST THEN BEGIN
    SalesLine2.UpdateAmounts;
    SalesLine2.MODIFY;
    END;
    ...

    Замени код 3

    ...IF "Line Amount" = "Inv. Discount Amount" THEN BEGIN
    Amount := 0;
    "VAT Base Amount" := 0;
    "Amount Including VAT" := 0;

    // Add the following line.
    IF ("Line No." <> 0) AND NOT ((Type = Type::"G/L Account") AND ("No." = CustPostingGr."Service Charge Acc.")) THEN
    // End of the added line.

    IF MODIFY THEN
    IF SalesLine2.FINDLAST THEN BEGIN
    SalesLine2.UpdateAmounts;
    SalesLine2.MODIFY;
    END;
    ...
  2. Промяна на кода на UpdateVATAmounts функцията в таблицата за покупки (39) както следва:
    Съществуващ код 1

    ...END;

    LOCAL PROCEDURE UpdateVATAmounts@38();
    VAR
    PurchLine2@1000 : Record 39;
    TotalLineAmount@1005 : Decimal;
    TotalInvDiscAmount@1004 : Decimal;
    TotalAmount@1001 : Decimal;
    TotalAmountInclVAT@1002 : Decimal;
    TotalQuantityBase@1003 : Decimal;
    ...

    Замени код 1

    ...END;

    LOCAL PROCEDURE UpdateVATAmounts@38();
    VAR
    PurchLine2@1000 : Record 39;

    // Add the following line.
    VendPostingGr@1009 : Record 93;
    // End of the added line.

    TotalLineAmount@1005 : Decimal;
    TotalInvDiscAmount@1004 : Decimal;
    TotalAmount@1001 : Decimal;
    TotalAmountInclVAT@1002 : Decimal;
    TotalQuantityBase@1003 : Decimal;
    ...

    Съществуващ код 2

    ...PurchLine2.SETFILTER(Amount,'>%1',0)
    ELSE
    PurchLine2.SETFILTER(Amount,'<%1',0);
    PurchLine2.SETRANGE("VAT Identifier","VAT Identifier");
    PurchLine2.SETRANGE("Tax Group Code","Tax Group Code");

    IF "Line Amount" = "Inv. Discount Amount" THEN BEGIN
    Amount := 0;
    "VAT Base Amount" := 0;
    "Amount Including VAT" := 0;
    ...

    Замени код 2

    ...PurchLine2.SETFILTER(Amount,'>%1',0)
    ELSE
    PurchLine2.SETFILTER(Amount,'<%1',0);
    PurchLine2.SETRANGE("VAT Identifier","VAT Identifier");
    PurchLine2.SETRANGE("Tax Group Code","Tax Group Code");

    // Add the following line.
    VendPostingGr.GET(PurchHeader."Vendor Posting Group");
    // End of the added line.

    IF "Line Amount" = "Inv. Discount Amount" THEN BEGIN
    Amount := 0;
    "VAT Base Amount" := 0;
    "Amount Including VAT" := 0;
    ...

    Съществуващ код 3

    ...IF "Line Amount" = "Inv. Discount Amount" THEN BEGIN
    Amount := 0;
    "VAT Base Amount" := 0;
    "Amount Including VAT" := 0;

    // Delete the following line.
    IF "Line No." <> 0 THEN
    // End of the deleted line.

    IF MODIFY THEN
    IF PurchLine2.FINDLAST THEN BEGIN
    PurchLine2.UpdateAmounts;
    PurchLine2.MODIFY;
    END;
    ...

    Замени код 3

    ...IF "Line Amount" = "Inv. Discount Amount" THEN BEGIN
    Amount := 0;
    "VAT Base Amount" := 0;
    "Amount Including VAT" := 0;

    // Add the following line.
    IF ("Line No." <> 0) AND NOT ((Type = Type::"G/L Account") AND ("No." = VendPostingGr."Service Charge Acc.")) THEN
    // End of the added line.

    IF MODIFY THEN
    IF PurchLine2.FINDLAST THEN BEGIN
    PurchLine2.UpdateAmounts;
    PurchLine2.MODIFY;
    END;
    ...

Необходими условия:

Трябва да имате един от следните продукти, за да приложите тази спешна корекция:

  • Microsoft Dynamics NAV 2009 Service Pack 1 (SP1)

  • Microsoft Dynamics NAV 2009 R2



Информация за премахване

Не можете да премахнете тази актуална корекция.

Статус

Microsoft потвърждава, че това е проблем в продуктите на Microsoft, изброени в раздела "Отнася се за".

Забележка: Това е статия "Бърза публикация", създадени директно от организацията за поддръжка на Microsoft. Информацията тук се предоставя "както-е" в отговор на появили се проблеми. В резултат на скоростта на предоставянето му материалите могат да съдържат печатни грешки и могат да бъдат коригирани по всяко време без предизвестие. Вижте Условия за други съображения.

Нуждаете ли се от още помощ?

Искате ли още опции?

Разгледайте ползите от абонамента, прегледайте курсовете за обучение, научете как да защитите устройството си и още.

Общностите ви помагат да задавате и отговаряте на въпроси, да давате обратна връзка и да получавате информация от експерти с богати знания.

Беше ли полезна тази информация?

Доколко сте доволни от качеството на езика?
Какво е повлияло на вашия потребителски опит?
Като натиснете „Подаване“, вашата обратна връзка ще се използва за подобряване на продуктите и услугите на Microsoft. Вашият ИТ администратор ще може да събира тези данни. Декларация за поверителност.

Благодарим ви за обратната връзка!

×