I v případě, že instalaci opravy hotfix 975264 v aplikaci Microsoft Dynamics NAV 2009 je nesprávná hodnota v poli "Zůstatek" v položce, která je vytvořena pro faktury


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


Zvažte následující scénář v produktu Microsoft Dynamics NAV 2009:
  • Instalaci opravy hotfix 975264.
    Další informace o opravě hotfix 975264 klepnutím na následující číslo článku databáze Microsoft Knowledge Base:
    975264 hodnota pole "Zůstatek" v položce, která je vytvořena pro platby je nesprávná v produktu Microsoft Dynamics NAV
  • Zadejte hodnotu v vyrovnání. Přesnost zaokrouhlení pole na kartě vyrovnání v dialogovém okně Nastavení financí .
  • Účtujete prodejní fakturu.
  • Zaúčtování deníku přijaté hotovosti pro prodejní fakturu.
V tomto scénáři je nesprávná hodnota v poli Zbývající částka v položce odpovídající. Žádná hodnota se má zobrazit v poli Zbývající částka .
K tomuto problému dochází v následujících produktů:
  • Aplikace Microsoft Dynamics NAV 2009 R2
  • Aplikace Microsoft Dynamics NAV 2009 Service Pack 1 (SP1)

Ř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 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 pomoci vysvětlit funkce určitého postupu, nemohou však následující příklady rozšířit o další funkce nebo vytvářet postupy podle vašich konkrétních požadavků.

Poznámka: Před instalací této opravy hotfix ověřte, že všichni uživatelé klienta Microsoft Navision odhlášeni systému. To zahrnuje uživatele klienta Microsoft Navision Application Services (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 objekt.


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ěnit kód v aktivační událost PostCust v finančního deníku.-Post řádku procedura (12) následujícím způsobem:
    Existující kód
    ...// Post the application
    ApplyCustLedgEntry(

    // Delete the following line.
    CVLedgEntryBuf,DtldCVLedgEntryBuf,GenJnlLine,GLSetup."Appln. Rounding Precision");

    // Post customer entry
    ...
    Změněný kód
    ...// Post the application
    ApplyCustLedgEntry(

    // Add the following line.
    CVLedgEntryBuf,DtldCVLedgEntryBuf,GenJnlLine);

    // Post customer entry
    ...
  2. Změnit kód v aktivační událost PostVend v finančního deníku.-Post řádku procedura (12) následujícím způsobem:
    Existující kód
    ...// Post the application
    ApplyVendLedgEntry(

    // Delete the following lines.
    CVLedgEntryBuf,DtldCVLedgEntryBuf,GenJnlLine,
    GLSetup."Appln. Rounding Precision");
    // End of the lines.

    // Post Vendor entry
    ...
    Změněný kód
    ...// Post the application
    ApplyVendLedgEntry(

    // Add the following line.
    CVLedgEntryBuf,DtldCVLedgEntryBuf,GenJnlLine);

    // Post Vendor entry
    ...
  3. Přidat nový místní parametr ve funkci ApplyCustLedgEntry v finančního deníku.-Post řádku procedura (12) a potom zadejte parametr takto:
    • Var: No
    • Název: ApplnRoundingPrecision
    • Datový typ: desetinné číslo
  4. Přidat novou místní proměnnou ve funkci ApplyCustLedgEntry v finančního deníku.-Post řádku procedura (12) a potom zadejte proměnné takto:
    • Název: ApplnRoundingPrecision
    • Datový typ: desetinné číslo
  5. Změňte kód ve funkci ApplyCustLedgEntry v finančního deníku.-Post řádku procedura (12) následujícím způsobem:
    Existující kód 1
    ...NewCVLedgEntryBuf2 := NewCVLedgEntryBuf;

    // Delete the following lines.
    IF NewCVLedgEntryBuf."Currency Code" <> '' THEN BEGIN
    Management of application of already posted entries
    IF NewCVLedgEntryBuf."Currency Code" <> ApplnCurrency.Code THEN
    ApplnCurrency.GET(NewCVLedgEntryBuf."Currency Code");
    ApplnRoundingPrecision := ApplnCurrency."Appln. Rounding Precision";
    END ELSE
    ApplnRoundingPrecision := GLSetup."Appln. Rounding Precision";
    // End of the lines.

    ApplyingDate := GenJnlLine."Posting Date";

    IF GenJnlLine."Applies-to Doc. No." <> '' THEN BEGIN
    ...
    Změněný kód 1
    ...NewCVLedgEntryBuf2 := NewCVLedgEntryBuf;

    ApplyingDate := GenJnlLine."Posting Date";

    IF GenJnlLine."Applies-to Doc. No." <> '' THEN BEGIN
    ...
    Existující kód 2
    ...// Management of posting in multiple currencies
    OldCVLedgEntryBuf2 := OldCVLedgEntryBuf;
    OldCVLedgEntryBuf.COPYFILTER(Positive,OldCVLedgEntryBuf2.Positive);

    IF NewCVLedgEntryBuf."Currency Code" <> OldCVLedgEntryBuf2."Currency Code" THEN BEGIN

    ...
    Náhradní kód 2
    ...// Management of posting in multiple currencies
    OldCVLedgEntryBuf2 := OldCVLedgEntryBuf;
    OldCVLedgEntryBuf.COPYFILTER(Positive,OldCVLedgEntryBuf2.Positive);

    // Add the following line.
    GetApplnRoundPrecision(ApplnRoundingPrecision,NewCVLedgEntryBuf,OldCVLedgEntryBuf);

    IF NewCVLedgEntryBuf."Currency Code" <> OldCVLedgEntryBuf2."Currency Code" THEN BEGIN
    ...
  6. Změňte kód ve funkci CustPostApplyCustLedgEntry v finančního deníku.-Post řádku procedura (12) následujícím způsobem:
    Existující kód
    ...// Post the application
    CustLedgEntry.CALCFIELDS(
    Amount,"Amount (LCY)","Remaining Amount","Remaining Amt. (LCY)",
    "Original Amount","Original Amt. (LCY)");
    TransferCustLedgEntry(CVLedgEntryBuf,CustLedgEntry,TRUE);
    ApplyCustLedgEntry(

    // Delete the following line.
    CVLedgEntryBuf,DtldCVLedgEntryBuf,GenJnlLine,GLSetup."Appln. Rounding Precision");

    TransferCustLedgEntry(CVLedgEntryBuf,CustLedgEntry,FALSE);
    CustLedgEntry.MODIFY;
    ...
    Změněný kód
    ...// Post the application
    CustLedgEntry.CALCFIELDS(
    Amount,"Amount (LCY)","Remaining Amount","Remaining Amt. (LCY)",
    "Original Amount","Original Amt. (LCY)");
    TransferCustLedgEntry(CVLedgEntryBuf,CustLedgEntry,TRUE);
    ApplyCustLedgEntry(

    // Add the following line.
    CVLedgEntryBuf,DtldCVLedgEntryBuf,GenJnlLine);

    TransferCustLedgEntry(CVLedgEntryBuf,CustLedgEntry,FALSE);
    CustLedgEntry.MODIFY;
    ...
  7. Přidat nový parametr místní v funkce ApplyVendLedgEntry v finančního deníku.-Post řádku procedura (12) a potom zadejte parametr takto:
    • Var: No
    • Název: ApplnRoundingPrecision
    • Datový typ: desetinné číslo
  8. Přidat novou místní proměnnou ve funkci ApplyVendLedgEntry v finančního deníku.-Post řádku procedura (12) a potom zadejte proměnné takto:
    • Název: ApplnRoundingPrecision
    • Datový typ: desetinné číslo
  9. Změňte kód ve funkci ApplyVendLedgEntry v finančního deníku.-Post řádku procedura (12) následujícím způsobem:
    Existující kód 1
    ...NewCVLedgEntryBuf2 := NewCVLedgEntryBuf;

    // Delete the following lines.
    IF NewCVLedgEntryBuf."Currency Code" <> '' THEN BEGIN
    // Management of application of already posted entries
    IF NewCVLedgEntryBuf."Currency Code" <> ApplnCurrency.Code THEN
    ApplnCurrency.GET(NewCVLedgEntryBuf."Currency Code");
    ApplnRoundingPrecision := ApplnCurrency."Appln. Rounding Precision";
    END ELSE
    ApplnRoundingPrecision := GLSetup."Appln. Rounding Precision";
    // End of the lines.

    ApplyingDate := GenJnlLine."Posting Date";

    IF GenJnlLine."Applies-to Doc. No." <> '' THEN BEGIN
    ...
    Změněný kód 1
    ...NewCVLedgEntryBuf2 := NewCVLedgEntryBuf;

    ApplyingDate := GenJnlLine."Posting Date";

    IF GenJnlLine."Applies-to Doc. No." <> '' THEN BEGIN
    ...
    Existující kód 2
    ...// Management of posting in multiple currencies
    OldCVLedgEntryBuf2 := OldCVLedgEntryBuf;
    OldCVLedgEntryBuf.COPYFILTER(Positive,OldCVLedgEntryBuf2.Positive);

    IF NewCVLedgEntryBuf."Currency Code" <> OldCVLedgEntryBuf2."Currency Code" THEN BEGIN
    ...
    Náhradní kód 2
    ...// Management of posting in multiple currencies
    OldCVLedgEntryBuf2 := OldCVLedgEntryBuf;
    OldCVLedgEntryBuf.COPYFILTER(Positive,OldCVLedgEntryBuf2.Positive);

    // Add the following line.
    GetApplnRoundPrecision(ApplnRoundingPrecision,NewCVLedgEntryBuf,OldCVLedgEntryBuf);

    IF NewCVLedgEntryBuf."Currency Code" <> OldCVLedgEntryBuf2."Currency Code" THEN BEGIN
    ...
  10. Změňte kód ve funkci VendPostApplyVendLedgEntry v finančního deníku.-Post řádku procedura (12) následujícím způsobem:
    Existující kód
    ...// Post the application
    VendLedgEntry.CALCFIELDS(
    Amount,"Amount (LCY)","Remaining Amount","Remaining Amt. (LCY)",
    "Original Amount","Original Amt. (LCY)");
    TransferVendLedgEntry(CVLedgEntryBuf,VendLedgEntry,TRUE);
    ApplyVendLedgEntry(

    // Delete the following line.
    CVLedgEntryBuf,DtldCVLedgEntryBuf,GenJnlLine,GLSetup."Appln. Rounding Precision");

    TransferVendLedgEntry(CVLedgEntryBuf,VendLedgEntry,FALSE);
    ...
    Změněný kód
    ...// Post the application
    VendLedgEntry.CALCFIELDS(
    Amount,"Amount (LCY)","Remaining Amount","Remaining Amt. (LCY)",
    "Original Amount","Original Amt. (LCY)");
    TransferVendLedgEntry(CVLedgEntryBuf,VendLedgEntry,TRUE);
    ApplyVendLedgEntry(

    // Add the following line.
    CVLedgEntryBuf,DtldCVLedgEntryBuf,GenJnlLine);

    TransferVendLedgEntry(CVLedgEntryBuf,VendLedgEntry,FALSE);
    ...
  11. Vytvořit nové funtion GetApplnRoundPrecision v finančního deníku.-Post řádku procedura (12). Chcete-li vytvořit tuto funkci, postupujte takto:
    1. Přidat nový parametr místní v funtion GetApplnRoundPrecision v finančního deníku.-Post řádku procedura (12) a potom zadejte parametr takto:
      • Var: Ano
      • Název: ApplnRoundingPrecision
      • Datový typ: desetinné číslo
    2. Přidat nový parametr místní v funtion GetApplnRoundPrecision v finančního deníku.-Post řádku procedura (12) a potom zadejte parametr takto:
      • Var: No
      • Název: NewCVLedgEntryBuf
      • Datový typ: záznam
      • Podtyp: dodav vstupní vyrovnávací paměti
    3. Přidat nový parametr místní v funtion GetApplnRoundPrecision v finančního deníku.-Post řádku procedura (12) a potom zadejte parametr takto:
      • Var: No
      • Název: OldCVLedgEntryBuf
      • Datový typ: záznam
      • Podtyp: dodav vstupní vyrovnávací paměti
    4. Přidat novou místní proměnnou v funtion GetApplnRoundPrecision v finančního deníku.-Post řádku procedura (12) a potom zadejte proměnné takto:
      • Název: CurrencyExistInledger
      • Datový typ: Boolean
    5. Přidat novou místní proměnnou v funtion GetApplnRoundPrecision v finančního deníku.-Post řádku procedura (12) a potom zadejte proměnné takto:
      • Název: Kód měny
      • Datový typ: kód
      • Délka: 20
    6. Přidejte následující kód v GetApplnRoundPrecision funtion v finančního deníku.-Post řádku procedura (12):
      IF NewCVLedgEntryBuf."Currency Code" <> '' THENCurrencyCode := NewCVLedgEntryBuf."Currency Code"
      ELSE
      CurrencyCode := OldCVLedgEntryBuf."Currency Code";
      IF CurrencyCode <> ApplnCurrency.Code THEN
      CurrencyExistInledger := ApplnCurrency.GET(CurrencyCode);

      IF CurrencyExistInledger THEN BEGIN
      IF ApplnCurrency."Appln. Rounding Precision" <> 0 THEN
      ApplnRoundingPrecision := ApplnCurrency."Appln. Rounding Precision"
      ELSE
      ApplnRoundingPrecision := GLSetup."Appln. Rounding Precision";
      END;

Předpoklady

Musí mít jednu z následujících produktů nainstalovali tuto opravu hotfix:
  • Aplikace Microsoft Dynamics NAV 2009 R2
  • Aplikace Microsoft Dynamics NAV 2009 Service Pack 1 (SP1)

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.