Přihlásit se pomocí účtu Microsoft
Přihlaste se nebo si vytvořte účet.
Dobrý den,
Vyberte jiný účet.
Máte více účtů.
Zvolte účet, pomocí kterého se chcete přihlásit.

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

Po instalaci opravy hotfix 2292157 a 2764340 pro aplikaci Microsoft Dynamics NAV 2009, Vyrovnat položky zákazníka formuláře a formuláře Vyrovnat položky dodavatele zobrazit nesprávné hodnoty v poli Zůstatek a skonto. Částka pole.

K tomuto problému dochází v následujících produktů:

  • Aplikace Microsoft Dynamics NAV 2009 Service Pack 1

  • Aplikace Microsoft Dynamics NAV 2009 R2

Další informace o opravách hotfix 2292157 a 2764340 získáte v následujícím článku znalostní báze Microsoft Knowledge Base:

2292157 pole "Zůstatek" a "skonta. Pole Částka"ve formuláři Vyrovnat položky zákazníka a ve formuláři Vyrovnat položky dodavatele zobrazit nesprávné hodnoty, pokud vyrovnat platbu s účtem několik otevřených dokumentů v aplikaci Microsoft Dynamics NAV

2764340 položky dodavatele je stále vybrán, přestože vymazány položky dodavatele dříve ve formuláři "Vyrovnat položky dodavatele" v aplikaci Microsoft Dynamics NAV 2009

Ř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 9015

    objektu.

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 HandlChosenEntries v theApply formulář položky zákazníka (232) takto:
    Existující kód 1

    ...CurrentAmount := CurrentAmount + AppliedCustLedgEntryTemp."Remaining Amount" -
    AppliedCustLedgEntryTemp."Remaining Pmt. Disc. Possible";
    END ELSE IF (ABS(CurrentAmount) = ABS(AppliedCustLedgEntryTemp."Remaining Amount" -
    AppliedCustLedgEntryTemp."Remaining Pmt. Disc. Possible"))
    THEN BEGIN

    // Delete the following lines.
    PmtDiscAmount := PmtDiscAmount + AppliedCustLedgEntryTemp."Remaining Pmt. Disc. Possible" + PossiblePmtDisc;
    CurrentAmount := CurrentAmount + AppliedCustLedgEntryTemp."Remaining Amount" -
    AppliedCustLedgEntryTemp."Remaining Pmt. Disc. Possible" - PossiblePmtDisc;
    PossiblePmtDisc := 0;
    // End of the deleted lines.

    AppliedAmount := AppliedAmount + CorrectionAmount;
    END ELSE IF (FromZeroGenJnl) THEN BEGIN
    PmtDiscAmount := PmtDiscAmount + AppliedCustLedgEntryTemp."Remaining Pmt. Disc. Possible";
    CurrentAmount := CurrentAmount +
    AppliedCustLedgEntryTemp."Remaining Amount" - AppliedCustLedgEntryTemp."Remaining Pmt. Disc. Possible";
    ...

    Změněný kód 1

    ...CurrentAmount := CurrentAmount + AppliedCustLedgEntryTemp."Remaining Amount" -
    AppliedCustLedgEntryTemp."Remaining Pmt. Disc. Possible";
    END ELSE IF (ABS(CurrentAmount) = ABS(AppliedCustLedgEntryTemp."Remaining Amount" -
    AppliedCustLedgEntryTemp."Remaining Pmt. Disc. Possible"))
    THEN BEGIN

    // Add the following lines.
    PmtDiscAmount := PmtDiscAmount + AppliedCustLedgEntryTemp."Remaining Pmt. Disc. Possible";
    CurrentAmount := CurrentAmount + AppliedCustLedgEntryTemp."Remaining Amount" -
    AppliedCustLedgEntryTemp."Remaining Pmt. Disc. Possible";
    // End of the added lines.

    AppliedAmount := AppliedAmount + CorrectionAmount;
    END ELSE IF (FromZeroGenJnl) THEN BEGIN
    PmtDiscAmount := PmtDiscAmount + AppliedCustLedgEntryTemp."Remaining Pmt. Disc. Possible";
    CurrentAmount := CurrentAmount +
    AppliedCustLedgEntryTemp."Remaining Amount" - AppliedCustLedgEntryTemp."Remaining Pmt. Disc. Possible";
    ...

    Existující kód 2

    ...END;
    CurrentAmount := CurrentAmount + AppliedCustLedgEntryTemp."Remaining Amount" -
    AppliedCustLedgEntryTemp."Remaining Pmt. Disc. Possible";
    END;
    END ELSE BEGIN

    // Delete the following lines.
    PossiblePmtDisc := AppliedCustLedgEntryTemp."Remaining Pmt. Disc. Possible";
    IF (((CurrentAmount - PossiblePmtDisc + AppliedCustLedgEntryTemp."Amount to Apply") * CurrentAmount) <= 0) THEN BEGIN
    PmtDiscAmount := PmtDiscAmount + PossiblePmtDisc;
    CurrentAmount := CurrentAmount - PossiblePmtDisc;
    PossiblePmtDisc := 0;
    AppliedAmount := AppliedAmount + CorrectionAmount;
    END;
    // End of the deleted lines.

    CurrentAmount := CurrentAmount + AppliedCustLedgEntryTemp."Amount to Apply";
    END;
    END ELSE BEGIN
    AppliedCustLedgEntryTemp.SETRANGE(Positive);
    AppliedCustLedgEntryTemp.FINDFIRST;
    ...

    Náhradní kód 2

    ...END;
    CurrentAmount := CurrentAmount + AppliedCustLedgEntryTemp."Remaining Amount" -
    AppliedCustLedgEntryTemp."Remaining Pmt. Disc. Possible";
    END;
    END ELSE BEGIN

    // Add the following lines.
    IF (((CurrentAmount + AppliedCustLedgEntryTemp."Amount to Apply") * CurrentAmount) <= 0) THEN
    AppliedAmount := AppliedAmount + CorrectionAmount;
    // End of the added lines.

    CurrentAmount := CurrentAmount + AppliedCustLedgEntryTemp."Amount to Apply";
    END;
    END ELSE BEGIN
    AppliedCustLedgEntryTemp.SETRANGE(Positive);
    AppliedCustLedgEntryTemp.FINDFIRST;
    ...
  2. Změňte kód ve funkci HandlChosenEntries ve formuláři Vyrovnat položky dodavatele (233) takto:
    Existující kód 1

    ...CurrentAmount := CurrentAmount + AppliedVendLedgEntryTemp."Remaining Amount" -
    AppliedVendLedgEntryTemp."Remaining Pmt. Disc. Possible";
    END ELSE IF (ABS(CurrentAmount) = ABS(AppliedVendLedgEntryTemp."Remaining Amount" -
    AppliedVendLedgEntryTemp."Remaining Pmt. Disc. Possible"))
    THEN BEGIN

    // Delete the following lines.
    PmtDiscAmount := PmtDiscAmount + AppliedVendLedgEntryTemp."Remaining Pmt. Disc. Possible" + PossiblePmtdisc;
    CurrentAmount := CurrentAmount + AppliedVendLedgEntryTemp."Remaining Amount" -
    AppliedVendLedgEntryTemp."Remaining Pmt. Disc. Possible" - PossiblePmtdisc;
    PossiblePmtdisc := 0;
    // End of the deleted lines.

    AppliedAmount := AppliedAmount + CorrectionAmount;
    END ELSE IF FromZeroGenJnl THEN BEGIN
    PmtDiscAmount := PmtDiscAmount + AppliedVendLedgEntryTemp."Remaining Pmt. Disc. Possible";
    CurrentAmount := CurrentAmount +
    AppliedVendLedgEntryTemp."Remaining Amount" - AppliedVendLedgEntryTemp."Remaining Pmt. Disc. Possible";
    ...

    Změněný kód 1

    ...CurrentAmount := CurrentAmount + AppliedVendLedgEntryTemp."Remaining Amount" -
    AppliedVendLedgEntryTemp."Remaining Pmt. Disc. Possible";
    END ELSE IF (ABS(CurrentAmount) = ABS(AppliedVendLedgEntryTemp."Remaining Amount" -
    AppliedVendLedgEntryTemp."Remaining Pmt. Disc. Possible"))
    THEN BEGIN

    // Add the following lines.
    PmtDiscAmount := PmtDiscAmount + AppliedVendLedgEntryTemp."Remaining Pmt. Disc. Possible";
    CurrentAmount := CurrentAmount + AppliedVendLedgEntryTemp."Remaining Amount" -
    AppliedVendLedgEntryTemp."Remaining Pmt. Disc. Possible";
    // End of the added lines.

    AppliedAmount := AppliedAmount + CorrectionAmount;
    END ELSE IF FromZeroGenJnl THEN BEGIN
    PmtDiscAmount := PmtDiscAmount + AppliedVendLedgEntryTemp."Remaining Pmt. Disc. Possible";
    CurrentAmount := CurrentAmount +
    AppliedVendLedgEntryTemp."Remaining Amount" - AppliedVendLedgEntryTemp."Remaining Pmt. Disc. Possible";
    ...

    Existující kód 2

    ...END;
    CurrentAmount := CurrentAmount + AppliedVendLedgEntryTemp."Remaining Amount" -
    AppliedVendLedgEntryTemp."Remaining Pmt. Disc. Possible";
    END;
    END ELSE BEGIN

    // Delete the following lines.
    PossiblePmtdisc := AppliedVendLedgEntryTemp."Remaining Pmt. Disc. Possible";
    IF (((CurrentAmount - PossiblePmtdisc + AppliedVendLedgEntryTemp."Amount to Apply") * CurrentAmount) >= 0) THEN BEGIN
    PmtDiscAmount := PmtDiscAmount + PossiblePmtdisc;
    CurrentAmount := CurrentAmount - PossiblePmtdisc;
    PossiblePmtdisc := 0;
    AppliedAmount := AppliedAmount + CorrectionAmount;
    END;
    // End of the deleted lines.

    CurrentAmount := CurrentAmount + AppliedVendLedgEntryTemp."Amount to Apply";
    END;
    END ELSE BEGIN
    AppliedVendLedgEntryTemp.SETRANGE(Positive);
    AppliedVendLedgEntryTemp.FINDFIRST;
    ...

    Náhradní kód 2

    ...END;
    CurrentAmount := CurrentAmount + AppliedVendLedgEntryTemp."Remaining Amount" -
    AppliedVendLedgEntryTemp."Remaining Pmt. Disc. Possible";
    END;
    END ELSE BEGIN

    // Add the following lines.
    IF (((CurrentAmount + AppliedVendLedgEntryTemp."Amount to Apply") * CurrentAmount) >= 0) THEN
    AppliedAmount := AppliedAmount + CorrectionAmount;
    // End of the added lines.

    CurrentAmount := CurrentAmount + AppliedVendLedgEntryTemp."Amount to Apply";
    END;
    END ELSE BEGIN
    AppliedVendLedgEntryTemp.SETRANGE(Positive);
    AppliedVendLedgEntryTemp.FINDFIRST;
    ...


Předpoklady

Musí mít jednu z následujících produktů nainstalovali tuto opravu hotfix:

  • Aplikace Microsoft Dynamics NAV 2009 Service Pack 1

  • Aplikace Microsoft Dynamics NAV 2009 R2

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.

Byly tyto informace užitečné?

Jak jste spokojeni s kvalitou jazyka?
Co ovlivnilo váš názor?
Po stisknutí tlačítka pro odeslání se vaše zpětná vazba použije k vylepšování produktů a služeb Microsoftu. Váš správce IT bude moci tato data shromažďovat. Prohlášení o zásadách ochrany osobních údajů.

Děkujeme vám za zpětnou vazbu.

×