Przejdź do głównej zawartości
Pomoc techniczna
Zaloguj się przy użyciu konta Microsoft
Zaloguj się lub utwórz konto.
Witaj,
Wybierz inne konto.
Masz wiele kont
Wybierz konto, za pomocą którego chcesz się zalogować.

Objawy

Po zainstalowaniu KB2982157, jeśli używasz funkcji podatku VAT dla pozycji wraz z więcej niż jednym partnerem, sumy sumę dla poszczególnych partnerów bez resetowania na zero w węgierskiej wersji programu Microsoft Dynamics NAV 2009 R2. Wykonaj kroki opisane w sekcji zmiany kodu , aby rozwiązać ten problem. Ten problem występuje w następujących produktach:

  • Węgierskiej wersji programu Microsoft Dynamics NAV 2009 R2

Rozwiązanie

Informacje o poprawce

Obsługiwana poprawka jest obecnie udostępniana przez firmę Microsoft. Jednak to jest przeznaczona tylko do usunięcia problemu opisanego w tym artykule. Zastosuj ją tylko w systemach, w których występuje ten problem. Ta poprawka może być wciąż w fazie testowania. Jeśli dany system nie jest poważnie narażony na ten problem, firma Microsoft zaleca, aby poczekać na następny dodatek service pack dla systemu Microsoft Dynamics NAV 2009 lub następną wersję systemu Microsoft Dynamics NAV, zawierający tę poprawkę.

Uwaga W wyjątkowych przypadkach opłaty, telefonujący do pomocy technicznej mogą zostać anulowane, jeśli pomocy technicznej dla systemu Microsoft Dynamics i produktów powiązanych Określa, że określonej aktualizacji, można rozwiązać swój problem. Koszty obsługi zwykłych zastosuje się do dodatkowych pytań i problemów, których nie można rozwiązać przy użyciu określonej aktualizacji.

Informacje dotyczące instalacji

Firma Microsoft podaje przykłady programowania wyłącznie, bez jakichkolwiek gwarancji wyrażonych wprost lub domyślnie. To obejmuje, ale nie jest ograniczona, ustawowej rękojmi co do przydatności handlowej lub przydatności do określonego celu. W tym artykule założono, że użytkownik zna demonstrowany język programowania oraz narzędzia, które są używane do tworzenia i debugowania procedur. Wykwalifikowani pracownicy pomocy technicznej firmy Microsoft mogą pomóc w wyjaśnieniu, jak działa określona procedura. Nie będą jednak modyfikować tych przykładów ani dodawać funkcjonalności i konstruować procedur w celu zaspokojenia określonych potrzeb użytkownika.

Uwaga Przed zainstalowaniem tej poprawki należy zweryfikować, że wszyscy użytkownicy klienta systemu Microsoft Dynamics NAV są wylogowani systemu. Obejmuje to usług systemu Microsoft Dynamics NAV aplikacji serwera (NAS). Powinny być użytkownika klienta, który jest zalogowany w momencie wdrożyć tę poprawkę.

Aby wdrożyć tę poprawkę, musi mieć licencję deweloperską.

Firma Microsoft zaleca, aby do konta użytkownika w oknie identyfikatorów logowania systemu Windows lub w oknie identyfikatorów logowania bazy danych być przypisany identyfikator roli "SUPER". Jeśli konto użytkownika nie można przypisać Identyfikatora roli "SUPER", należy sprawdzić, czy konto użytkownika ma następujące uprawnienia:

  • Uprawnienie Modyfikacja dla obiektu, który będzie zmieniany.

  • Uprawnienie Execute obiektu 5210 identyfikator obiektu systemu i 9015 identyfikator obiektu systemu

    obiekt.

Uwaga Nie trzeba mieć prawa do magazynów danych, chyba że konieczne jest przeprowadzenie naprawy danych.

Zmiany kodu

Uwaga Zawsze test poprawki kodu w kontrolowanym środowisku przed zastosowaniem poprawki na komputerach produkcyjnych.

Aby rozwiązać ten problem, wykonaj następujące kroki:

  1. Zmień kod w raporcie wyszczególnione deklaracji VAT (14522) w następujący sposób:
    Istniejący kod

    ...PartnerId := PartnerBuffer."Partner ID";
    PartnerVatId := PartnerBuffer."VAT Registration No.";
    PartnerName := GetPartnerName(PartnerType,PartnerId);

    Buffer.RESET;
    SetBufferFilters(PartnerType,PartnerId,PartnerVatId);
    ...

    Kod zastępczy

    ...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);
    ...
  2. Zmień kod w zmiennych globalnych w raporcie wyszczególnione deklaracji VAT (14522) w następujący sposób:
    Istniejący kod 1

    ...VAR
    CompanyInfo@1170000002 : Record 79;
    Buffer@1170000007 : TEMPORARY Record 14550;
    PartnerBuffer@1170000008 : TEMPORARY Record 14551;
    PartnerName@1170000012 : Text[250];
    PartnerVatId@1170000013 : Text[30];
    ...

    Kod zastępczy 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];
    ...

    Istniejący kod 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
    ...

    Kod zastępczy 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
    ...
  3. Zmień kod w funkcji CalcPartnerTotals w raporcie wyszczególnione deklaracji VAT (14522) w następujący sposób:
    Istniejący kod

    ... 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.
    ...

    Kod zastępczy

    ...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.
    ...

Wymagania wstępne

Musi mieć jedną z następujących produktów, w celu zastosowania tej poprawki:

  • Węgierskiej wersji programu Microsoft Dynamics NAV 2009 R2

Dodatkowo musi mieć KB2982157 i MSDNAV2009R2ItemizedVAtHungary zainstalowane.

Informacje dotyczące usuwania

Nie można usunąć tej poprawki.

Stan

Firma Microsoft potwierdziła, że jest to problem występujący w produktach firmy Microsoft wymienionych w sekcji „Dotyczy”.

Uwaga Jest to artykuł " szybkiej publikacji" tworzony bezpośrednio przez organizację pomocy technicznej firmy Microsoft. Informacje zawarte w niniejszym dokumencie są dostarczane jako odpowiedź na pojawiające się problemy. W wyniku przyspieszonego udostępnienia, materiały te mogą zawierać błędy typograficzne i mogą być zmieniane w dowolnym czasie bez uprzedzenia. Zobacz Warunki użytkowaniadla innych względów.

Potrzebujesz dalszej pomocy?

Chcesz uzyskać więcej opcji?

Poznaj korzyści z subskrypcji, przeglądaj kursy szkoleniowe, dowiedz się, jak zabezpieczyć urządzenie i nie tylko.

Społeczności pomagają zadawać i odpowiadać na pytania, przekazywać opinie i słuchać ekspertów z bogatą wiedzą.

Czy te informacje były pomocne?

Jaka jest jakość języka?
Co wpłynęło na Twoje wrażenia?
Jeśli naciśniesz pozycję „Wyślij”, Twoja opinia zostanie użyta do ulepszania produktów i usług firmy Microsoft. Twój administrator IT będzie mógł gromadzić te dane. Oświadczenie o ochronie prywatności.

Dziękujemy za opinię!

×