Tento článek se týká aplikace Microsoft Dynamics NAV ve všech zemích a všechna národní prostředí jazyka.

Příznaky

Předpokládejme, nastavit pro dodavatele v produktu Microsoft Dynamics NAV 2009 jako Metoda vyrovnáníVyrovnat nejstarší . A zaúčtujte dobropis jedna a dvě faktury pomocí deníku. Jako výsledek systém se vztahuje na obě faktury dobropisu. Později zrušit všechny dokumenty. V takovém případě při spuštění funkce Reverzní transakce pro řádek dobropisu, systém vytvoří nepotřebné věcné položky.K tomuto problému dochází v následujících produktů:

  • Microsoft Dynamics NAV 2009

  • Aplikace Microsoft Dynamics NAV 2009 R2

Řešení

Informace o opravě hotfix

Podporovaná oprava hotfix je nyní k dispozici od společnosti Microsoft. Však je určena pouze k odstranění problému popsaného v tomto článku. Použijte ji pouze u systémů, ve kterých dochází k tomuto konkrétnímu problému. Tato oprava hotfix může být dále testována. Proto pokud jste závažně tento problém, doporučujeme počkat na další aktualizaci service pack produktu Microsoft Dynamics NAV 2009 nebo další verze produktu Microsoft Dynamics NAV, která obsahuje tuto opravu hotfix.Poznámka: Ve zvláštních případech poplatky, které jsou třeba obvykle zaplatit za telefonní hovory mohou být stornovány, jestliže pracovník technické podpory společnosti Microsoft Dynamics a souvisejících produktů Určuje, že konkrétní aktualizace odstraní váš problém. Výdaje na technickou podporu použije dalších otázek a problémů, které nelze vyřešit konkrétní aktualizací.

Informace o instalaci

Společnost Microsoft poskytuje ukázky programování pouze pro ilustraci bez žádné záruky výslovně uvedené nebo odvozené. To zahrnuje, ale není omezen pouze na předpokládané záruky obchodovatelnosti nebo vhodnosti pro určitý účel. Tento článek předpokládá, že jste obeznámeni s programovacím jazykem, který je předmětem ukázky a s nástroji, které slouží k vytvoření a ladění skriptu. Pracovníci podpory společnosti Microsoft mohou vysvětlit funkce určitého postupu. Nemohou však následující příklady rozšířit o další funkce nebo konstrukce podle konkrétních požadavků.Poznámka: Před instalací této opravy hotfix ověřte, že všichni uživatelé klienta Microsoft Dynamics NAV odhlášeni systému. To zahrnuje služby Microsoft Dynamics NAV Application Server (NAS). Je třeba klienta pouze uživatel přihlášený při implementaci opravy hotfix.Chcete-li implementovat tuto opravu hotfix, musí mít licenci vývojáře.Doporučujeme, aby uživatelský účet v okně přihlášení systému Windows nebo v okně přihlášení databáze přidělí "SUPER" ID role. Pokud uživatelský účet nelze přiřadit ID role "SUPER", musíte ověřit, že uživatelský účet má následující oprávnění:

  • Změnit oprávnění pro objekt, který budete měnit.

  • Oprávnění ke spuštění pro System Object ID 5210 objekt a System Object ID 9015objektu.

Poznámka: Nemáte práva k úložištím dat. Pokud nebudete provádět opravu dat.

Změny kódu

Poznámka: Vždy otestujte opravy kódu v kontrolovaném prostředí před instalací opravy v provozních počítačích.Chcete-li vyřešit tento problém, postupujte takto:

  1. Změňte kód ve funkci InsertReversalEntry v tabulce Položka storna (179) takto:Existující kód 1

    ...CLEAR(DtldCustLedgEntry);          DtldCustLedgEntry.SETCURRENTKEY("Transaction No.","Customer No.","Entry Type");          DtldCustLedgEntry.SETRANGE(DtldCustLedgEntry."Transaction No.",CustLedgEntry."Transaction No.");          DtldCustLedgEntry.SETRANGE(DtldCustLedgEntry."Customer No.",CustLedgEntry."Customer No.");          DtldCustLedgEntry.SETFILTER(            DtldCustLedgEntry."Entry Type",'<>%1',DtldCustLedgEntry."Entry Type"::"Initial Entry");// Delete the following line.          IF DtldCustLedgEntry.FIND('-') THEN BEGIN// End of the deleted line.            IF RevType = RevType::Register THEN              ERROR(Text012,Number);// Delete the following lines.            CLEAR(DtldCustLedgEntry);             DtldCustLedgEntry.SETCURRENTKEY("Cust. Ledger Entry No.");             DtldCustLedgEntry.SETRANGE("Cust. Ledger Entry No.",CustLedgEntry."Entry No.");             DtldCustLedgEntry.SETRANGE(Unapplied,TRUE);             IF DtldCustLedgEntry.FIND('-') THEN BEGIN               REPEAT                 TempRevertTransactionNo.Number := DtldCustLedgEntry."Transaction No.";                 IF TempRevertTransactionNo.INSERT THEN;               UNTIL DtldCustLedgEntry.NEXT = 0;             END;           END; // End of the deleted lines.        UNTIL CustLedgEntry.NEXT = 0;      IF VendLedgEntry.FIND('-') THEN        REPEAT          CLEAR(ReversalEntry);...

    Změněný kód 1

    ...CLEAR(DtldCustLedgEntry);          DtldCustLedgEntry.SETCURRENTKEY("Transaction No.","Customer No.","Entry Type");          DtldCustLedgEntry.SETRANGE(DtldCustLedgEntry."Transaction No.",CustLedgEntry."Transaction No.");          DtldCustLedgEntry.SETRANGE(DtldCustLedgEntry."Customer No.",CustLedgEntry."Customer No.");          DtldCustLedgEntry.SETFILTER(            DtldCustLedgEntry."Entry Type",'<>%1',DtldCustLedgEntry."Entry Type"::"Initial Entry");// Add the following line.          IF NOT DtldCustLedgEntry.ISEMPTY THEN// End of the added line.            IF RevType = RevType::Register THEN              ERROR(Text012,Number);// Add the following line.          CheckDtldCustLedgEntry(CustLedgEntry);// End of the added line.        UNTIL CustLedgEntry.NEXT = 0;      IF VendLedgEntry.FIND('-') THEN        REPEAT          CLEAR(ReversalEntry);...

    Existující kód 2

    ...CLEAR(DtldVendLedgEntry);          DtldVendLedgEntry.SETCURRENTKEY("Transaction No.","Vendor No.","Entry Type");          DtldVendLedgEntry.SETRANGE(DtldVendLedgEntry."Transaction No.",VendLedgEntry."Transaction No.");          DtldVendLedgEntry.SETRANGE(DtldVendLedgEntry."Vendor No.",VendLedgEntry."Vendor No.");          DtldVendLedgEntry.SETFILTER(            DtldVendLedgEntry."Entry Type",'<>%1',DtldVendLedgEntry."Entry Type"::"Initial Entry");// Delete the following line.          IF DtldVendLedgEntry.FIND('-') THEN BEGIN // End of the deleted line.            IF RevType = RevType::Register THEN              ERROR(Text012,Number);// Delete the following lines.            CLEAR(DtldVendLedgEntry);             DtldVendLedgEntry.SETCURRENTKEY("Vendor Ledger Entry No.");             DtldVendLedgEntry.SETRANGE("Vendor Ledger Entry No.",VendLedgEntry."Entry No.");             DtldVendLedgEntry.SETRANGE(Unapplied,TRUE);             IF DtldVendLedgEntry.FIND('-') THEN BEGIN               REPEAT                 TempRevertTransactionNo.Number := DtldVendLedgEntry."Transaction No.";                 IF TempRevertTransactionNo.INSERT THEN;               UNTIL DtldVendLedgEntry.NEXT = 0;             END;           END;// End of the deleted lines.        UNTIL VendLedgEntry.NEXT = 0;      IF BankAccLedgEntry.FIND('-') THEN        REPEAT          CLEAR(ReversalEntry);...

    Náhradní kód 2

    ...CLEAR(DtldVendLedgEntry);          DtldVendLedgEntry.SETCURRENTKEY("Transaction No.","Vendor No.","Entry Type");          DtldVendLedgEntry.SETRANGE(DtldVendLedgEntry."Transaction No.",VendLedgEntry."Transaction No.");          DtldVendLedgEntry.SETRANGE(DtldVendLedgEntry."Vendor No.",VendLedgEntry."Vendor No.");          DtldVendLedgEntry.SETFILTER(            DtldVendLedgEntry."Entry Type",'<>%1',DtldVendLedgEntry."Entry Type"::"Initial Entry");// Add the following line.          IF NOT DtldVendLedgEntry.ISEMPTY THEN// End of the added line.            IF RevType = RevType::Register THEN              ERROR(Text012,Number);// Add the following line.          CheckDtldVendLedgEntry(VendLedgEntry);// End of the added line.        UNTIL VendLedgEntry.NEXT = 0;      IF BankAccLedgEntry.FIND('-') THEN        REPEAT          CLEAR(ReversalEntry);...
  2. Změňte kód ve funkci CheckDtldCustLedgEntry v tabulce Položka storna (179) takto:Existující kód

    ...LOCAL PROCEDURE CheckDtldCustLedgEntry@2(CustLedgEntry@1000 : Record 21) : Boolean;    VAR      DtldCustLedgEntry@1001 : Record 379;    BEGIN// Delete the following lines.      DtldCustLedgEntry.SETCURRENTKEY("Cust. Ledger Entry No.");      DtldCustLedgEntry.SETRANGE("Cust. Ledger Entry No.",CustLedgEntry."Entry No.");      IF DtldCustLedgEntry.FIND('-') THEN        REPEAT          IF (DtldCustLedgEntry."Entry Type" <> DtldCustLedgEntry."Entry Type"::"Initial Entry") AND             (NOT DtldCustLedgEntry.Unapplied)          THEN            ERROR(              Text000,CustLedgEntry.TABLECAPTION,CustLedgEntry."Entry No.");        UNTIL DtldCustLedgEntry.NEXT = 0;// End of the deleted lines.    END;...

    Změněný kód

    ...LOCAL PROCEDURE CheckDtldCustLedgEntry@2(CustLedgEntry@1000 : Record 21) : Boolean;    VAR      DtldCustLedgEntry@1001 : Record 379;    BEGIN// Add the following lines.      DtldCustLedgEntry.SETCURRENTKEY("Cust. Ledger Entry No.","Entry Type");      DtldCustLedgEntry.SETRANGE("Cust. Ledger Entry No.",CustLedgEntry."Entry No.");      DtldCustLedgEntry.SETFILTER("Entry Type",'<>%1',DtldCustLedgEntry."Entry Type"::"Initial Entry");      DtldCustLedgEntry.SETRANGE(Unapplied,FALSE);      IF NOT DtldCustLedgEntry.ISEMPTY THEN        ERROR(Text000,CustLedgEntry.TABLECAPTION,CustLedgEntry."Entry No.");// End of the added lines.    END;...
  3. Změňte kód ve funkci CheckDtldVendLedgEntry v tabulce Položka storna (179) takto:Existující kód

    ...LOCAL PROCEDURE CheckDtldVendLedgEntry@28(VendLedgEntry@1000 : Record 25) : Boolean;    VAR      DtldVendLedgEntry@1001 : Record 380;    BEGIN// Delete the following lines.      DtldVendLedgEntry.SETCURRENTKEY("Vendor Ledger Entry No.");      DtldVendLedgEntry.SETRANGE("Vendor Ledger Entry No.",VendLedgEntry."Entry No.");      IF DtldVendLedgEntry.FIND('-') THEN        REPEAT          IF (DtldVendLedgEntry."Entry Type" <> DtldVendLedgEntry."Entry Type"::"Initial Entry") AND             (NOT DtldVendLedgEntry.Unapplied)          THEN            ERROR(              Text000,VendLedgEntry.TABLECAPTION,VendLedgEntry."Entry No.");        UNTIL DtldVendLedgEntry.NEXT = 0;// End of the deleted lines.    END;...

    Změněný kód

    ...LOCAL PROCEDURE CheckDtldVendLedgEntry@28(VendLedgEntry@1000 : Record 25) : Boolean;    VAR      DtldVendLedgEntry@1001 : Record 380;    BEGIN// Add the following lines.      DtldVendLedgEntry.SETCURRENTKEY("Vendor Ledger Entry No.","Entry Type");      DtldVendLedgEntry.SETRANGE("Vendor Ledger Entry No.",VendLedgEntry."Entry No.");      DtldVendLedgEntry.SETFILTER("Entry Type",'<>%1',DtldVendLedgEntry."Entry Type"::"Initial Entry");      DtldVendLedgEntry.SETRANGE(Unapplied,FALSE);      IF NOT DtldVendLedgEntry.ISEMPTY THEN        ERROR(Text000,VendLedgEntry.TABLECAPTION,VendLedgEntry."Entry No.");// End of the added lines.    END;...

Předpoklady

Musíte mít nainstalován do použití této opravy hotfix aplikace Microsoft Dynamics NAV 2009.

Informace o odinstalaci

Tato oprava hotfix nelze odebrat.

Stav

Společnost Microsoft potvrdila, že se jedná o problém v produktech společnosti Microsoft, které jsou uvedeny v části "Platí pro".

Poznámka: Toto je článek "Rychlé publikování" vytvářen přímo v rámci odborné pomoci společnosti Microsoft. Informace obsažené v tomto dokumentu jsou poskytovány tak, jak je v reakci na vznikající problémy. V důsledku rychlosti v jeho zpřístupnění materiály, mohou obsahovat typografické chyby a mohou být upraveny kdykoli bez předchozího upozornění. Viz Podmínky použitípro další aspekty.

Potřebujete další pomoc?

Chcete další možnosti?

Prozkoumejte výhody předplatného, projděte si školicí kurzy, zjistěte, jak zabezpečit své zařízení a mnohem více.

Komunity vám pomohou klást otázky a odpovídat na ně, poskytovat zpětnou vazbu a vyslechnout odborníky s bohatými znalostmi.