Funkce plánování objednávek vypočítá nesprávné návrhy "Množství na zakázku", při použití prostředí Vyrob na zakázku v produktu Microsoft Dynamics NAV

Šablona: CPR – Šablona pro opravu kódu aplikace Navision

Chyba č: 164543 (Údržba obsahu)

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

Příznaky

Funkce plánování objednávek vypočítá nesprávné návrhy "Množství na zakázku", při použití prostředí Vyrob na zakázku v produktu Microsoft Dynamics NAV. K tomuto problému dochází, pokud používáte víceúrovňový kusovník (BOM).
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)

  • Microsoft Dynamics NAV 2009

  • Aplikace Microsoft Dynamics NAV 5.0 Service Pack 1 (SP1)

Příčina

Systém používá rekurzivní funkci, která vždy změní množství nalezené položky (Kusovníku vytvoří "stromu" některé položky může dojít, pokud jednou nebo vícekrát). Nicméně totiž nesprávné chování, všechny podřízené aktualizované položky by měly být buď odstraněny nebo aktualizovány.

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

Pokud není tato oprava hotfix k volnému stahování (tj. v článku není uvedena veřejná adresa URL opravy hotfix), vyžaduje její distribuce technickým vedoucím, členem týmu a vedoucím přičemž následující předpoklady:

  • Opravu hotfix mohou získat zákazníci se vyskytla chyba, která je uvedena v části "Příznaky".

  • Musí sledovat zákazníci Chcete-li odeslat a dodat v další aktualizaci service Pack, až bude k dispozici (Pokud bude vydána aktualizace service pack).

Tato oprava hotfix aktualizaci service pack aplikace Microsoft Dynamics NAV 2009 není plánováno.



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. Vytvořte místní funkce UpdateRelatedComponent v procedura (99000809):

    ...LOCAL PROCEDURE UpdateRelatedComponent@15(ParentReqLine@1000 : Record 246);
    WITH PlanningComponent DO BEGIN
    SETCURRENTKEY("Worksheet Template Name","Worksheet Batch Name","Worksheet Line No.","Item No.");
    SETRANGE("Worksheet Line No.",ParentReqLine."Line No.");
    SETFILTER("Item No.",'<>%1','');
    SETFILTER("Expected Quantity",'<>0');
    SETFILTER("Planning Level Code",'<>0');
    IF FIND('-') THEN
    REPEAT
    IF LineHasBeenCreated(ChildReqLine,PlanningComponent) THEN BEGIN
    UpdateRelatedComponent(ChildReqLine);
    IF ChildReqLine.Quantity <> "Expected Quantity" THEN BEGIN
    // qty has to be updated, there is a new need of component
    ChildReqLine.BlockDynamicTracking(Blocked);
    ChildReqLine.VALIDATE(Quantity,ChildReqLine.Quantity - "Expected Quantity");
    ChildReqLine.MODIFY;

    // updating qty of component for parent
    VALIDATE("Quantity per","Quantity per");
    MODIFY;
    END ELSE
    // line will be recreated
    ChildReqLine.DELETE(TRUE);
    END;
    UNTIL NEXT = 0;
    END;
    ...


    Ve funkci přidáte následující parametry:

    • Název: PlanningComponent; Datový typ: Záznam (99000829)

    • Název: ChildReqLine; Datový typ: Záznam (246)

  2. Vytvořte místní funkce LineHasBeenCreated v procedura (99000829):

    ...LOCAL PROCEDURE LineHasBeenCreated@18(VAR ChildReqLine@1000 : Record 246;PlanningComponent@1001 : Record 99000829) : Boolean;
    WITH ChildReqLine DO BEGIN
    SETCURRENTKEY("Worksheet Template Name","Journal Batch Name",Type,"No.");
    SETRANGE("Worksheet Template Name",PlanningComponent."Worksheet Template Name");
    SETRANGE("Journal Batch Name",PlanningComponent."Worksheet Batch Name");
    SETRANGE(Type,Type::Item);
    SETRANGE("No.",PlanningComponent."Item No.");
    SETRANGE("Variant Code",PlanningComponent."Variant Code");
    SETRANGE("Ref. Order Type","Ref. Order Type"::"Prod. Order");
    SETRANGE("Ref. Order Status",PlanningComponent."Ref. Order Status");
    SETRANGE("Ref. Order No.",PlanningComponent."Ref. Order No.");
    SETFILTER("Planning Level",'>%1',0);
    EXIT(FINDFIRST);
    END;
    ...
  3. Změňte kód ve funkci InsertPlanningLine v procedura (99000809) takto:
    Existující kód

    ... IF ReqLine2."Planning Level" < ReqLine."Planning Level" THEN
    ReqLine2."Planning Level" := ReqLine."Planning Level";

    ReqLine2.MODIFY;
    ...

    Změněný kód

    ... IF ReqLine2."Planning Level" <ReqLine."Planning Level" THEN
    ReqLine2."Planning Level" := ReqLine."Planning Level";

    // the ReqLine2 can have children which has to be delete or updated
    // Add the following line.
    UpdateRelatedComponent(ReqLine2);

    ReqLine2.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 (SP1)

  • Microsoft Dynamics NAV 2009

  • Aplikace Microsoft Dynamics NAV 5.0 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".

Odkazy

VSTF DynamicsNAV SE: 291912

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.

Autor: cosborne
Zapisovatel: v-tinw
Odborný recenzent: cosborne
Redaktor:

Potřebujete další pomoc?

Rozšiřte své znalosti a dovednosti
Projít školení
Získejte nové funkce jako první
Připojit se k programu Microsoft Insider

Byly tyto informace užitečné?

Děkujeme za váš názor!

Děkujeme vám za váš názor! Pravděpodobně bude užitečné, když vás spojíme s některým z našich agentů podpory Office.

×