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

Симптоми

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

  • Microsoft Dynamics NAV 2009 R2

  • Microsoft Dynamics NAV 2009 Service Pack 1 (SP1)

  • Microsoft Dynamics NAV 2009


Решение

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

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

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



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

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

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

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

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

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

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



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

Промени код

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

  1. Създаване на нови GetCPGInvRoundAcc функция, която използва типа на кода за стойността на връщане (дължина 20) в таблицата ред в продажби (37). За да създадете тази функция, изпълнете следните стъпки:

    1. Добавяне на нова локална променлива и след това задайте променливата както следва:

      • Име: Cust@1012

      • Тип данни: запис

      • Подтип: клиент

    2. Добавяне на нова локална променлива и след това задайте променливата както следва:

      • Име: CustPostingGroup@1013

      • Тип данни: запис

      • Подтип: Счетоводната група

    3. Добавяне на нова локална променлива и след това задайте променливата както следва:

      • Име: CustTemplate@1014

      • Тип данни: запис

      • Подтип: шаблон за клиент

    4. Добавяне на нова локална променлива и след това задайте променливата както следва:

      • Име: SalesSetup@1008

      • Тип данни: запис

      • Подтип: продажби и вземания

    5. Добавете кода по следния начин:

      SalesSetup.GET;IF SalesSetup."Invoice Rounding" THEN BEGIN
      IF Cust.GET(SalesHeader."Bill-to Customer No.") THEN
      CustPostingGroup.GET(Cust."Customer Posting Group")
      ELSE
      IF CustTemplate.GET(SalesHeader."Sell-to Customer Template Code") THEN
      CustPostingGroup.GET(CustTemplate."Customer Posting Group");
      END;
      EXIT(CustPostingGroup."Invoice Rounding Account");
  2. Изтрийте следните локални променливи в CalcVATAmountLines функция в таблицата Ред от продажби (37):

    • Cust@1012

    • CustPostingGroup@1013

    • CustTemplate@1014

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

    …WITH SalesLine DO BEGIN
    SETRANGE("Document Type",SalesHeader."Document Type");
    SETRANGE("Document No.",SalesHeader."No.");
    SalesSetup.GET;
    IF SalesSetup."Invoice Rounding" THEN BEGIN
    IF Cust.GET(SalesHeader."Bill-to Customer No.") THEN
    CustPostingGroup.GET(Cust."Customer Posting Group")
    ELSE
    IF CustTemplate.GET(SalesHeader."Sell-to Customer Template Code") THEN
    CustPostingGroup.GET(CustTemplate."Customer Posting Group");
    END;
    IF FINDSET THEN
    REPEAT
    IF NOT ZeroAmountLine(QtyType) THEN BEGIN
    IF (Type = Type::"G/L Account") AND NOT "Prepayment Line" THEN
    RoundingLineInserted := ("No." = CustPostingGroup."Invoice Rounding Account") OR RoundingLineInserted;
    IF "VAT Calculation Type" IN
    ["VAT Calculation Type"::"Reverse Charge VAT","VAT Calculation Type"::"Sales Tax"]

    Замени код

    …WITH SalesLine DO BEGIN
    SETRANGE("Document Type",SalesHeader."Document Type");
    SETRANGE("Document No.",SalesHeader."No.");
    IF FINDSET THEN
    REPEAT
    IF NOT ZeroAmountLine(QtyType) THEN BEGIN
    IF (Type = Type::"G/L Account") AND NOT "Prepayment Line" THEN
    RoundingLineInserted := ("No." = GetCPGInvRoundAcc) OR RoundingLineInserted;
    IF "VAT Calculation Type" IN
    ["VAT Calculation Type"::"Reverse Charge VAT","VAT Calculation Type"::"Sales Tax"]

  4. Създаване на нови GetVPGInvRoundAcc функция, която използва типа на кода (дължина 20) за върнатата стойност в таблицата за покупки (39). За да създадете тази функция, изпълнете следните стъпки:

    1. Добавяне на нова локална променлива и след това задайте променливата както следва:

      • Име: Vendor@1000

      • Тип данни: запис

      • Подтип: доставчик

    2. Добавяне на нова локална променлива и след това задайте променливата както следва:

      • Име: VendorPostingGroup@1001

      • Тип данни: запис

      • Подтип: Доставчик

    3. Добавяне на нова локална променлива и след това задайте променливата както следва:

      • Име: PurchSetup@1002

      • Тип данни: запис

      • Подтип: покупки и задължения

    4. Добавете кода по следния начин:

      PurchSetup.GET;  IF PurchSetup."Invoice Rounding" THEN  
      IF Vendor.GET(PurchHeader."Pay-to Vendor No.") THEN
      VendorPostingGroup.GET(Vendor."Vendor Posting Group");
      EXIT(VendorPostingGroup."Invoice Rounding Account");


  5. Изтрийте следните локални променливи в CalcVATAmountLines функция в таблицата за покупки (39):

    • Vendor@1012

    • VendorPostingGroup@1013

  6. Промяна на кода на CalcVATAmountLines функцията в таблицата за покупки (39):
    Съществуващ код

    …WITH PurchLine DO BEGIN
    SETRANGE("Document Type",PurchHeader."Document Type");
    SETRANGE("Document No.",PurchHeader."No.");
    PurchSetup.GET;
    IF PurchSetup."Invoice Rounding" THEN BEGIN
    Vendor.GET(PurchHeader."Pay-to Vendor No.");
    VendorPostingGroup.GET(Vendor."Vendor Posting Group");
    END;
    IF FINDSET THEN
    REPEAT
    IF NOT ZeroAmountLine(QtyType) THEN BEGIN
    IF (Type = Type::"G/L Account") AND NOT "Prepayment Line" THEN
    RoundingLineInserted := ("No." = VendorPostingGroup."Invoice Rounding Account") OR RoundingLineInserted;
    IF "VAT Calculation Type" IN
    ["VAT Calculation Type"::"Reverse Charge VAT","VAT Calculation Type"::"Sales Tax"]

    Замени код

    …WITH PurchLine DO BEGIN
    SETRANGE("Document Type",PurchHeader."Document Type");
    SETRANGE("Document No.",PurchHeader."No.");
    IF FINDSET THEN
    REPEAT
    IF NOT ZeroAmountLine(QtyType) THEN BEGIN
    IF (Type = Type::"G/L Account") AND NOT "Prepayment Line" THEN
    RoundingLineInserted := ("No." = GetVPGInvRoundAcc) OR RoundingLineInserted;
    IF "VAT Calculation Type" IN
    ["VAT Calculation Type"::"Reverse Charge VAT","VAT Calculation Type"::"Sales Tax"]

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

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

  • Microsoft Dynamics NAV 2009 R2

  • Microsoft Dynamics NAV 2009 Service Pack 1 (SP1)

  • Microsoft Dynamics NAV 2009


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

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

Статус

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

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

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

Разширете уменията си

Преглед на обучението >

Получавайте първи новите функции

Присъединете се към Microsoft приобщени >

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

Доколко сте доволни от качеството на езика?
Какво е повлияло на вашия потребителски опит?

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

×