Applies ToDynamics NAV 2009

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, že nastavíte Výchozí množství k dodání / příjmu pole v dialogovém okně Nastavení nákupu & závazků v produktu Microsoft Dynamics NAV 2009. Však při vrácení zaúčtovaného příjmu/dodávky, pole k příjmu není prázdné. Je-li obnovit původní prodejní nebo nákupní řádek, hodnoty k dodání/příjmu je aktualizován zbývajícího množství k dodání/příjmu. 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

Ř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 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ěňte kód ve funkci UpdatePurchLine v proceduře vrátit řízení účtování (5817) takto:Existující kód 1

    ...      PROCEDURE UpdatePurchLine@16(PurchLine@1000 : Record 39;UndoQty@1002 : Decimal;UndoQtyBase@1005 : Decimal;VAR TempUndoneItemLedgEntry@1001 : TEMPORARY Record 32);      VAR        xPurchLine@1004 : Record 39;        ReservePurchLine@1003 : Codeunit 99000834;      BEGIN        WITH PurchLine DO BEGIN          xPurchLine := PurchLine;          CASE "Document Type" OF            "Document Type"::"Return Order":...

    Změněný kód 1

    ...      PROCEDURE UpdatePurchLine@16(PurchLine@1000 : Record 39;UndoQty@1002 : Decimal;UndoQtyBase@1005 : Decimal;VAR TempUndoneItemLedgEntry@1001 : TEMPORARY Record 32);      VAR        xPurchLine@1004 : Record 39;        ReservePurchLine@1003 : Codeunit 99000834;// Add the following line.       PurchSetup@1020 : Record 312;      BEGIN        WITH PurchLine DO BEGIN          xPurchLine := PurchLine;          CASE "Document Type" OF            "Document Type"::"Return Order":...

    Existující kód 2

    ...            "Document Type"::Order:              BEGIN                "Quantity Received" := "Quantity Received" - UndoQty;                "Qty. Received (Base)" := "Qty. Received (Base)" - UndoQtyBase;                InitOutstanding;// Delete the following line.               InitQtyToReceive;              END;            ELSE              FIELDERROR("Document Type");          END;          MODIFY;...

    Náhradní kód 2

    ...            "Document Type"::Order:              BEGIN                "Quantity Received" := "Quantity Received" - UndoQty;                "Qty. Received (Base)" := "Qty. Received (Base)" - UndoQtyBase;                InitOutstanding;// Add the following lines.               PurchSetup.GET;               IF PurchSetup."Default Qty. to Ship/Rcv." = PurchSetup."Default Qty. to Ship/Rcv."::Blank THEN                 PurchLine."Qty. to Receive" := 0               ELSE                 InitQtyToReceive;// End of the lines.              END;            ELSE              FIELDERROR("Document Type");          END;          MODIFY;...
  2. Změňte kód ve funkci UpdateSalesLine v proceduře vrátit řízení účtování (5817) takto:Existující kód 1

    ...      PROCEDURE UpdateSalesLine@15(SalesLine@1000 : Record 37;UndoQty@1002 : Decimal;UndoQtyBase@1005 : Decimal;VAR TempUndoneItemLedgEntry@1001 : TEMPORARY Record 32);      VAR        xSalesLine@1004 : Record 37;        ReserveSalesLine@1003 : Codeunit 99000832;      BEGIN        WITH SalesLine DO BEGIN          xSalesLine := SalesLine;          CASE "Document Type" OF            "Document Type"::"Return Order":              BEGIN...

    Změněný kód 1

    ...      PROCEDURE UpdateSalesLine@15(SalesLine@1000 : Record 37;UndoQty@1002 : Decimal;UndoQtyBase@1005 : Decimal;VAR TempUndoneItemLedgEntry@1001 : TEMPORARY Record 32);      VAR        xSalesLine@1004 : Record 37;        ReserveSalesLine@1003 : Codeunit 99000832;// Add the following line.       SalesSetup@1020 : Record 311;      BEGIN// Add the following line.       SalesSetup.GET;        WITH SalesLine DO BEGIN          xSalesLine := SalesLine;          CASE "Document Type" OF            "Document Type"::"Return Order":              BEGIN...

    Existující kód 2

    ...            "Document Type"::"Return Order":              BEGIN                "Return Qty. Received" := "Return Qty. Received" - UndoQty;                "Return Qty. Received (Base)" := "Return Qty. Received (Base)" - UndoQtyBase;                InitOutstanding;// Delete the following line.               InitQtyToReceive;              END;            "Document Type"::Order:              BEGIN                "Quantity Shipped" := "Quantity Shipped" - UndoQty;                "Qty. Shipped (Base)" := "Qty. Shipped (Base)" - UndoQtyBase;...

    Náhradní kód 2

    ...            "Document Type"::"Return Order":              BEGIN                "Return Qty. Received" := "Return Qty. Received" - UndoQty;                "Return Qty. Received (Base)" := "Return Qty. Received (Base)" - UndoQtyBase;                InitOutstanding;// Add the following lines.               IF SalesSetup."Default Quantity to Ship" = SalesSetup."Default Quantity to Ship"::Blank THEN                 "Qty. to Ship" := 0               ELSE                 InitQtyToReceive;// End of the lines.              END;            "Document Type"::Order:              BEGIN                "Quantity Shipped" := "Quantity Shipped" - UndoQty;                "Qty. Shipped (Base)" := "Qty. Shipped (Base)" - UndoQtyBase;...

    Existující kód 3

    ...            "Document Type"::Order:              BEGIN                "Quantity Shipped" := "Quantity Shipped" - UndoQty;                "Qty. Shipped (Base)" := "Qty. Shipped (Base)" - UndoQtyBase;                InitOutstanding;// Delete the following line.               InitQtyToShip;              END;            ELSE              FIELDERROR("Document Type");          END;          MODIFY;...

    Změněný kód 3

    ...            "Document Type"::Order:              BEGIN                "Quantity Shipped" := "Quantity Shipped" - UndoQty;                "Qty. Shipped (Base)" := "Qty. Shipped (Base)" - UndoQtyBase;                InitOutstanding;// Add the following lines.               IF SalesSetup."Default Quantity to Ship" = SalesSetup."Default Quantity to Ship"::Blank THEN                 "Qty. to Ship" := 0               ELSE                 InitQtyToShip;// End of the lines.              END;            ELSE              FIELDERROR("Document Type");          END;          MODIFY;...

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

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.