Applies ToDynamics NAV 2009

Tento článok sa vzťahuje na Microsoft Dynamics NAV 2009 pre všetky krajiny a všetky jazykové locales.

Príznaky

Predpokladajme, že spustíte plánovanie zošita a Automatická zostava Kusovník Kit nastavenie pre položku Kit dostatok zásob v Microsoft Dynamics NAV 2009 R2 a Microsoft Dynamics NAV 2009 Service Pack 1 (SP1). Pri pokuse o účtovaní predajnej objednávky pre položku Kit, zobrazí nasledujúce chybové hlásenie:

Neexistuje položka rezervácie. Identifikácia polia a hodnoty: číslo = "Entry_Number", pozitívne = "Áno"

Riešenie

Informácie o rýchlej oprave

Rýchla oprava je k dispozícii od spoločnosti Microsoft. Je však určená iba opraviť problém popísaný v tomto článku. Použite ju iba v počítačoch s týmto konkrétnym problémom. Môže, že táto rýchla oprava bude ďalej testovaná. Ak vám nespôsobuje tento problém, odporúčame vám počkať na ďalšiu Microsoft Dynamics NAV 2009 service pack alebo ďalšej verzii Microsoft Dynamics NAV, ktorá obsahuje túto rýchlu opravu.Poznámka: V špeciálnych prípadoch sa poplatky, ktoré sú telefonickú podporu nemusia účtovať ak technickú podporu Professional pre Microsoft Dynamics a súvisiace produkty zistí, že táto konkrétna aktualizácia vyrieši váš problém. Ďalšie otázky a žiadosti o technickú podporu, ktoré sa netýkajú tejto špecifickej aktualizácie, podliehajú bežným sadzbám za poskytovanie technickej podpory.

Informácie o inštalácii

Spoločnosť Microsoft poskytuje príklady programovacieho kódu len ako názornú ukážku bez vyjadrených či predpokladaných záruk. Tie okrem iného zahŕňajú predpokladané záruky obchodovateľnosti alebo vhodnosti na konkrétny účel. Tento článok predpokladá, že ovládate predvádzaný programovací jazyk a nástroje, ktoré sa používajú na vytváranie a ladenie procedúr. Pracovníci technickej podpory spoločnosti Microsoft vám môžu vysvetliť fungovanie konkrétneho postupu, ale neupravia tieto príklady s cieľom poskytnutia pridanej funkčnosti ani nevytvoria procedúry zohľadňujúce vaše konkrétne požiadavky.Poznámka: Skôr než nainštalujete túto rýchlu opravu, overte, že všetky Microsoft Navision klienta používatelia odhlásení systému. Toto zahŕňa používateľov klienta Microsoft Navision aplikácie služby (NAS). Mali by ste byť iba klient prihláseného používateľa je pri implementácii túto rýchlu opravu.Vykonávať túto rýchlu opravu, musíte mať licencie pre vývojárov.Odporúča sa, že konto používateľa v okne prihlásenia systému Windows alebo v okne prihlásenia do databázy pridelí "SUPER" úlohu ID. Ak používateľské konto nemožno priradiť úlohu ID "SUPER", musíte overiť, že používateľské konto má nasledujúce povolenia:

  • Zmeniť povolenia pre objekt, ktorý sa zmení.

  • Povolenia na vykonanie systému objekt ID 5210 a systém objekt ID 9015 objektu.

Poznámka: Nemusíte mať práva ukladá údaje, pokiaľ budete musieť vykonať opravy údajov.

Zmeny kódu

Poznámka: Vždy skúšobný opravy v prostredí kontrolované pred použitím opravy výroby počítačov.Ak chcete vyriešiť tento problém, zmeniť kód vo funkcii DemandtoInvProfile vyrovnanie zásob profilu procedúra (99000854):Poznámka: 10, 26/11 sa mierne zmeny na tento článok KB na inline kód s kódom, ktorá bola vydaná pre NAV 5.0SP1. Funkčnosť sa nezmení. Niektoré riadky, ktorý sa v časti "Pridanie" náhradný kód;

Riadok: InventoryProfile. " Číslo riadka": = LineNo; Zmena: InventoryProfile. " Číslo riadka": = NextLineNo;Linka: LineNo: = LineNo + 1; bol odstránený.

Existujúci kód

...InventoryProfile.SETCURRENTKEY("Line No.");SalesLine.SETCURRENTKEY(Type,"No.","Variant Code","Drop Shipment","Location Code","Document Type","Shipment Date");SalesLine.SETFILTER("Document Type",'%1|%2',SalesLine."Document Type"::Order,SalesLine."Document Type"::"Return Order");SalesLine.SETRANGE(Type,SalesLine.Type::Item);SalesLine.SETRANGE("No.",Item."No.");Item.COPYFILTER("Location Filter",SalesLine."Location Code");Item.COPYFILTER("Variant Filter",SalesLine."Variant Code");SalesLine.SETFILTER("Outstanding Qty. (Base)",'<>0');SalesLine.SETFILTER("Shipment Date",'>%1&<=%2',0D,ToDate);IF SalesLine.FIND('-') THEN  REPEAT    InventoryProfile.INIT;    InventoryProfile."Line No." := NextLineNo;    InventoryProfile.TransferFromSalesLine(SalesLine,TempItemTrkgEntry);    IF InventoryProfile.IsSupply THEN      InventoryProfile.ChangeSign;    InventoryProfile.INSERT;  UNTIL SalesLine.NEXT = 0;ServiceLine.SETCURRENTKEY(Type,"No.","Variant Code","Location Code","Posting Date");ServiceLine.SETRANGE("Document Type",ServiceLine."Document Type"::Order);ServiceLine.SETRANGE(Type,ServiceLine.Type::Item);ServiceLine.SETRANGE("No.",Item."No.");Item.COPYFILTER("Location Filter",ServiceLine."Location Code");Item.COPYFILTER("Variant Filter",ServiceLine."Variant Code");ServiceLine.SETFILTER("Outstanding Qty. (Base)",'<>0');ServiceLine.SETFILTER("Posting Date",'>%1&<=%2',0D,ToDate);IF ServiceLine.FIND('-') THEN  REPEAT    InventoryProfile.INIT;    InventoryProfile."Line No." := NextLineNo;    InventoryProfile.TransferFromServiceInvLine(ServiceLine,TempItemTrkgEntry);    IF InventoryProfile.IsSupply THEN      InventoryProfile.ChangeSign;    InventoryProfile.INSERT;  UNTIL ServiceLine.NEXT = 0;ReqLine.SETCURRENTKEY("Ref. Order Type","Ref. Order Status","Ref. Order No.","Ref. Line No.");ReqLine.SETRANGE("Ref. Order Type",ReqLine."Ref. Order Type"::"Prod. Order");ProdOrderComp.SETCURRENTKEY("Item No.","Variant Code","Location Code",Status,"Due Date");ProdOrderComp.SETRANGE("Item No.",Item."No.");Item.COPYFILTER("Location Filter",ProdOrderComp."Location Code");Item.COPYFILTER("Variant Filter",ProdOrderComp."Variant Code");ProdOrderComp.SETRANGE(Status,ProdOrderComp.Status::Planned,ProdOrderComp.Status::Released);ProdOrderComp.SETFILTER("Due Date",'>%1&<=%2',0D,ToDate);IF ProdOrderComp.FIND('-') THEN  REPEAT    ReqLine.SETRANGE("Ref. Order Status",ProdOrderComp.Status);    ReqLine.SETRANGE("Ref. Order No.",ProdOrderComp."Prod. Order No.");    ReqLine.SETRANGE("Ref. Line No.",ProdOrderComp."Prod. Order Line No.");    ReqLine.SETRANGE("Operation No.",'');    IF NOT ReqLine.FIND('-') THEN BEGIN      InventoryProfile.INIT;      InventoryProfile."Line No." := NextLineNo;      InventoryProfile.TransferFromComponent(ProdOrderComp,TempItemTrkgEntry);      IF InventoryProfile.IsSupply THEN        InventoryProfile.ChangeSign;      InventoryProfile.INSERT;    END;  UNTIL ProdOrderComp.NEXT = 0;PlanningComponent.SETCURRENTKEY("Item No.","Variant Code","Location Code","Due Date");PlanningComponent.SETRANGE("Item No.",Item."No.");Item.COPYFILTER("Location Filter",PlanningComponent."Location Code");Item.COPYFILTER("Variant Filter",PlanningComponent."Variant Code");PlanningComponent.SETFILTER("Due Date",'>%1&<=%2',0D,ToDate);IF PlanningComponent.FIND('-') THEN  REPEAT    InventoryProfile.INIT;    InventoryProfile."Line No." := NextLineNo;    InventoryProfile."Item No." := Item."No.";    InventoryProfile.TransferFromPlanComponent(PlanningComponent,TempItemTrkgEntry);    IF InventoryProfile.IsSupply THEN      InventoryProfile.ChangeSign;    InventoryProfile.INSERT;  UNTIL PlanningComponent.NEXT = 0;TransferReqLine.SETCURRENTKEY(Type,"No.","Variant Code","Transfer-from Code","Transfer Shipment Date");TransferReqLine.SETRANGE("Replenishment System",TransferReqLine."Replenishment System"::Transfer);TransferReqLine.SETRANGE(Type,TransferReqLine.Type::Item);TransferReqLine.SETRANGE("No.",Item."No.");Item.COPYFILTER("Location Filter",TransferReqLine."Transfer-from Code");Item.COPYFILTER("Variant Filter",TransferReqLine."Variant Code");TransferReqLine.SETFILTER("Transfer Shipment Date",'>%1&<=%2',0D,ToDate);IF TransferReqLine.FIND('-') THEN  REPEAT    InventoryProfile.INIT;    InventoryProfile."Line No." := NextLineNo;    InventoryProfile."Item No." := Item."No.";    InventoryProfile.TransferFromOutboundTransfPlan(TransferReqLine,TempItemTrkgEntry);    IF InventoryProfile.IsSupply THEN      InventoryProfile.ChangeSign;    InventoryProfile.INSERT;  UNTIL TransferReqLine.NEXT = 0;TransLine.SETCURRENTKEY("Item No.");TransLine.SETRANGE("Item No.",Item."No.");Item.COPYFILTER("Variant Filter",TransLine."Variant Code");Item.COPYFILTER("Location Filter",TransLine."Transfer-from Code");TransLine.SETFILTER("Shipment Date",'>%1&<=%2',0D,ToDate);FilterIsSetOnLocation := Item.GETFILTER("Location Filter") <> '';IF TransLine.FIND('-') THEN  REPEAT    InventoryProfile.INIT;    InventoryProfile."Line No." := NextLineNo;    InventoryProfile."Item No." := Item."No.";    InventoryProfile.TransferFromOutboundTransfer(TransLine,TempItemTrkgEntry);    IF InventoryProfile.IsSupply THEN      InventoryProfile.ChangeSign;    IF FilterIsSetOnLocation THEN      InventoryProfile."Transfer Location Not Planned" := TransferLocationIsFilteredOut(Item,TransLine);    InventoryProfile.INSERT;  UNTIL TransLine.NEXT = 0;...

Nahradenie kódu

...InventoryProfile.SETCURRENTKEY("Line No.");SalesLine.SETCURRENTKEY(Type,"No.","Variant Code","Drop Shipment","Location Code","Document Type","Shipment Date");SalesLine.SETFILTER("Document Type",'%1|%2',SalesLine."Document Type"::Order,SalesLine."Document Type"::"Return Order");SalesLine.SETRANGE(Type,SalesLine.Type::Item);SalesLine.SETRANGE("No.",Item."No.");Item.COPYFILTER("Location Filter",SalesLine."Location Code");Item.COPYFILTER("Variant Filter",SalesLine."Variant Code");SalesLine.SETFILTER("Outstanding Qty. (Base)",'<>0');SalesLine.SETFILTER("Shipment Date",'>%1&<=%2',0D,ToDate);// Add the following line.SalesLine.SETRANGE("Build Kit",FALSE);// End of the line.IF SalesLine.FIND('-') THEN  REPEAT    InventoryProfile.INIT;    InventoryProfile."Line No." := NextLineNo;    InventoryProfile.TransferFromSalesLine(SalesLine,TempItemTrkgEntry);    IF InventoryProfile.IsSupply THEN      InventoryProfile.ChangeSign;    InventoryProfile.INSERT;  UNTIL SalesLine.NEXT = 0;// Add the following lines.KitSalesLine.SETCURRENTKEY("Document Type",Type,"No.","Variant Code","Location Code","Shipment Date");KitSalesLine.SETRANGE("Document Type",KitSalesLine."Document Type"::Order);KitSalesLine.SETRANGE(Type,KitSalesLine.Type::Item);KitSalesLine.SETRANGE("No.",Item."No.");Item.COPYFILTER("Location Filter",KitSalesLine."Location Code");Item.COPYFILTER("Variant Filter",KitSalesLine."Variant Code");KitSalesLine.SETFILTER("Outstanding Qty. (Base)",'<>0');KitSalesLine.SETFILTER("Shipment Date",'>%1&<=%2',0D,ToDate);IF KitSalesLine.FINDFIRST THEN  REPEAT    InventoryProfile.INIT;    InventoryProfile."Line No." := NextLineNo;    InventoryProfile.TransferFromKitSalesLine(KitSalesLine,TempItemTrkgEntry);    IF InventoryProfile.IsSupply THEN      InventoryProfile.ChangeSign;    InventoryProfile.INSERT;  UNTIL KitSalesLine.NEXT = 0;// End of the lines.ServiceLine.SETCURRENTKEY(Type,"No.","Variant Code","Location Code","Posting Date");ServiceLine.SETRANGE("Document Type",ServiceLine."Document Type"::Order);ServiceLine.SETRANGE(Type,ServiceLine.Type::Item);ServiceLine.SETRANGE("No.",Item."No.");Item.COPYFILTER("Location Filter",ServiceLine."Location Code");Item.COPYFILTER("Variant Filter",ServiceLine."Variant Code");ServiceLine.SETFILTER("Outstanding Qty. (Base)",'<>0');ServiceLine.SETFILTER("Posting Date",'>%1&<=%2',0D,ToDate);IF ServiceLine.FIND('-') THEN  REPEAT    InventoryProfile.INIT;    InventoryProfile."Line No." := NextLineNo;    InventoryProfile.TransferFromServiceInvLine(ServiceLine,TempItemTrkgEntry);    IF InventoryProfile.IsSupply THEN      InventoryProfile.ChangeSign;    InventoryProfile.INSERT;  UNTIL ServiceLine.NEXT = 0;ReqLine.SETCURRENTKEY("Ref. Order Type","Ref. Order Status","Ref. Order No.","Ref. Line No.");ReqLine.SETRANGE("Ref. Order Type",ReqLine."Ref. Order Type"::"Prod. Order");ProdOrderComp.SETCURRENTKEY("Item No.","Variant Code","Location Code",Status,"Due Date");ProdOrderComp.SETRANGE("Item No.",Item."No.");Item.COPYFILTER("Location Filter",ProdOrderComp."Location Code");Item.COPYFILTER("Variant Filter",ProdOrderComp."Variant Code");ProdOrderComp.SETRANGE(Status,ProdOrderComp.Status::Planned,ProdOrderComp.Status::Released);ProdOrderComp.SETFILTER("Due Date",'>%1&<=%2',0D,ToDate);IF ProdOrderComp.FIND('-') THEN  REPEAT    ReqLine.SETRANGE("Ref. Order Status",ProdOrderComp.Status);    ReqLine.SETRANGE("Ref. Order No.",ProdOrderComp."Prod. Order No.");    ReqLine.SETRANGE("Ref. Line No.",ProdOrderComp."Prod. Order Line No.");    ReqLine.SETRANGE("Operation No.",'');    IF NOT ReqLine.FIND('-') THEN BEGIN      InventoryProfile.INIT;      InventoryProfile."Line No." := NextLineNo;      InventoryProfile.TransferFromComponent(ProdOrderComp,TempItemTrkgEntry);      IF InventoryProfile.IsSupply THEN        InventoryProfile.ChangeSign;      InventoryProfile.INSERT;    END;  UNTIL ProdOrderComp.NEXT = 0;PlanningComponent.SETCURRENTKEY("Item No.","Variant Code","Location Code","Due Date");PlanningComponent.SETRANGE("Item No.",Item."No.");Item.COPYFILTER("Location Filter",PlanningComponent."Location Code");Item.COPYFILTER("Variant Filter",PlanningComponent."Variant Code");PlanningComponent.SETFILTER("Due Date",'>%1&<=%2',0D,ToDate);IF PlanningComponent.FIND('-') THEN  REPEAT    InventoryProfile.INIT;    InventoryProfile."Line No." := NextLineNo;    InventoryProfile."Item No." := Item."No.";    InventoryProfile.TransferFromPlanComponent(PlanningComponent,TempItemTrkgEntry);    IF InventoryProfile.IsSupply THEN      InventoryProfile.ChangeSign;    InventoryProfile.INSERT;  UNTIL PlanningComponent.NEXT = 0;TransferReqLine.SETCURRENTKEY(Type,"No.","Variant Code","Transfer-from Code","Transfer Shipment Date");TransferReqLine.SETRANGE("Replenishment System",TransferReqLine."Replenishment System"::Transfer);TransferReqLine.SETRANGE(Type,TransferReqLine.Type::Item);TransferReqLine.SETRANGE("No.",Item."No.");Item.COPYFILTER("Location Filter",TransferReqLine."Transfer-from Code");Item.COPYFILTER("Variant Filter",TransferReqLine."Variant Code");TransferReqLine.SETFILTER("Transfer Shipment Date",'>%1&<=%2',0D,ToDate);IF TransferReqLine.FIND('-') THEN  REPEAT    InventoryProfile.INIT;    InventoryProfile."Line No." := NextLineNo;    InventoryProfile."Item No." := Item."No.";    InventoryProfile.TransferFromOutboundTransfPlan(TransferReqLine,TempItemTrkgEntry);    IF InventoryProfile.IsSupply THEN      InventoryProfile.ChangeSign;    InventoryProfile.INSERT;  UNTIL TransferReqLine.NEXT = 0;TransLine.SETCURRENTKEY("Item No.");TransLine.SETRANGE("Item No.",Item."No.");Item.COPYFILTER("Variant Filter",TransLine."Variant Code");Item.COPYFILTER("Location Filter",TransLine."Transfer-from Code");TransLine.SETFILTER("Shipment Date",'>%1&<=%2',0D,ToDate);FilterIsSetOnLocation := Item.GETFILTER("Location Filter") <> '';IF TransLine.FIND('-') THEN  REPEAT    InventoryProfile.INIT;    InventoryProfile."Line No." := NextLineNo;    InventoryProfile."Item No." := Item."No.";    InventoryProfile.TransferFromOutboundTransfer(TransLine,TempItemTrkgEntry);    IF InventoryProfile.IsSupply THEN      InventoryProfile.ChangeSign;    IF FilterIsSetOnLocation THEN      InventoryProfile."Transfer Location Not Planned" := TransferLocationIsFilteredOut(Item,TransLine);    InventoryProfile.INSERT;  UNTIL TransLine.NEXT = 0;...

Požiadavky

Musíte mať jednu z nasledovných produktov nainštalovaný chcete použiť túto rýchlu opravu:

  • Microsoft Dynamics NAV 2009 R2

  • Microsoft Dynamics NAV 2009 Service Pack 1

Informácie o odstránení

Nemôžete odstrániť túto rýchlu opravu.

Stav

Spoločnosť Microsoft potvrdila, že ide o problém v produktoch spoločnosti Microsoft, ktoré sú uvedené v časti Vzťahuje sa na.

Poznámka: To je "Rýchlo publikovať" článok vytvorené priamo v rámci organizácie technickej podpory spoločnosti Microsoft. Uvedené informácie sa poskytuje ako-v reakcii na naliehavé problémy. Rýchlosťou robiť materiály môžu obsahovať typografické chyby a môžu byť kedykoľvek bez predchádzajúceho upozornenia. Prečítajte si Podmienky používania z iných dôvodov.

Potrebujete ďalšiu pomoc?

Chcete ďalšie možnosti?

Môžete preskúmať výhody predplatného, prehľadávať školiace kurzy, naučiť sa zabezpečiť svoje zariadenie a ešte oveľa viac.

Komunity pomôžu s kladením otázok a odpovedaním na ne, s poskytovaním pripomienok a so získavaním informácií od odborníkov s bohatými znalosťami.