आरक्षण डुप्लिकेट प्रविष्टियों के लिए दो बार Microsoft Dynamics नेविगेशन 2009 में किसी आइटम के लिए योजना इंजन चलाने पर उत्पन्न होते हैं


यह आलेख Microsoft Dynamics नेविगेशन करने के लिए सभी देशों और भाषा पर सभी स्थानों के लिए लागू होता है।

लक्षण


किसी आइटम के लिए योजना इंजन Microsoft Dynamics नेविगेशन 2009 में शामिल एक मांग के साथ कि आप चलाएँ, मान लें। क्या आप आइटम के लिए योजना इंजन को फिर से चलाएँ। माँग चल रही, दूसरी बार में शामिल नहीं है, तो इस स्थिति में, आरक्षण डुप्लिकेट प्रविष्टियाँ जनरेट किया गया है।
नोट स्थान वेयरहाउस कार्यक्षमता या नहीं का उपयोग करें कि क्या यह समस्या उत्पन्न होती है।
यह समस्या निम्न उत्पादों में होती है:
  • Microsoft Dynamics नेविगेशन 2009 R2
  • Microsoft Dynamics नेविगेशन 2009 सर्विस पैक 1 (SP1)

समाधान


हॉटफिक्स जानकारी

अब एक समर्थित हॉटफिक्स Microsoft से उपलब्ध है। हालाँकि, यह केवल इस आलेख में वर्णित समस्या को ठीक करने के लिए अभिप्रेत है। यह जो इस विशिष्ट समस्या का अनुभव कर रहे हैं केवल उन्ही सिस्टमों पर लागू करें। यह हॉटफ़िक्स अतिरिक्त परीक्षण प्राप्त हो सकता है। इसलिए, अगर आप इस समस्या से बुरी तरह प्रभावित नहीं हैं, तो हम सुझाव देंगे कि आप अगले Microsoft Dynamics नेविगेशन सर्विस पैक या इस हॉटफ़िक्स वाले अगले Microsoft Dynamics नेविगेशन संस्करण के लिए प्रतीक्षा करें।

नोट विशेष मामलों में, निर्धारित करता है कोई विशिष्ट अद्यतन आपकी समस्या का निराकरण शुल्क जो सामान्यतया समर्थन कॉल किसी तकनीकी समर्थन विशेषज्ञ तो Microsoft Dynamics और संबंधित उत्पादों के लिए रद्द किया जा सकता है के लिए जाते हैं। अतिरिक्त समर्थन प्रश्नों और उन समस्याओं जो विशिष्ट में समस्याग्रस्त अद्यतन के योग्य नहीं सामान्य समर्थन शुल्क लागू होंगे।


स्थापना जानकारी

Microsoft प्रोग्रामिंग उदाहरण केवल चित्रण के लिए वारंटी के बिना, या तो व्यक्त या नहीं देता है। यह शामिल है, लेकिन करने के लिए, बिक्री या किसी विशेष उद्देश्य के लिए उपयुक्तता की अव्यक्त वॉरंटी तक सीमित नहीं है। यह आलेख मानता है कि आप वर्णन किया जा रहा है प्रोग्रामिंग भाषा के साथ और बनाने के लिए और प्रक्रियाएँ डीबग करने के लिए उपयोग किए जाने वाले उपकरणों के साथ परिचित हैं। Microsoft समर्थन इंजीनियर एक विशेष कार्यविधि की कार्यप्रणाली को समझाने में सहायता कर सकते हैं, लेकिन वे इन उदाहरणों कार्यक्षमता जोड़ देने या आपकी विशिष्ट आवश्यकताओं को पूरा करने के लिए कार्यविधियाँ कार्यप्रणालियों के लिए संशोधित नहीं करेंगे।

नोट इस हॉटफिक्स को स्थापित करने से पहले, सत्यापित करें कि सिस्टम बंद सभी Microsoft Navision क्लाइंट उपयोगकर्ता लॉग ऑन हैं। यह Microsoft Navision अनुप्रयोग सेवाओं (NAS) क्लाइंट उपयोगकर्ता शामिल हैं। आप इस हॉटफिक्स को लागू करते समय लॉग किया गया है केवल क्लाइंट उपयोगकर्ता होना चाहिए।

इस हॉटफिक्स को लागू करने के लिए, यदि आप कोई डेवलपर लाइसेंस होना आवश्यक है।

हम अनुशंसा करते हैं कि उस उपयोगकर्ता खाते को Windows लॉगिन विंडो में या डेटाबेस लॉगिन विंडो में "सुपर" भूमिका id असाइन किया उपयोगकर्ता खाता "सुपर" भूमिका ID असाइन नहीं किया जा सकता है, तो आप उपयोगकर्ता खाते को निम्न अनुमतियाँ हैं सत्यापित होना चाहिए:
  • संशोधित अनुमति ऑब्जेक्ट आप परिवर्तित हो जाएगा के लिए।
  • निष्पादन अनुमति सिस्टम ऑब्जेक्ट ID 5210 ऑब्जेक्ट और सिस्टम ऑब्जेक्ट ID 9015 ऑब्जेक्ट के लिए है।


नोट क्या आपके पास डेटा सुधार करने के लिए है जब तक कि डेटा संग्रह करने के लिए अधिकार के पास नहीं है।

कोड परिवर्तन

नोट यदि आप को लागू करने से पहले हमेशा परीक्षण कोड एक नियंत्रित वातावरण में फिक्सेस अपने उत्पादन कंप्यूटर्स के लिए हल करता है।
इस समस्या को हल करने के लिए, निम्न चरणों का पालन करें:
  1. आरक्षण इंजन Mgt. codeunit (99000831) में CloseReservEntry फ़ंक्शन में कोड निम्नानुसार परिवर्तन:
    मौजूदा कोड
    ...ReservEntry2.MODIFY;
    ReservEntry2."Quantity (Base)" :=
    ReservMgt.MatchSurplus(ReservEntry2,SurplusReservEntry,ReservEntry2."Quantity (Base)",NOT ReservEntry2.Positive,
    AvailabilityDate,Item."Order Tracking Policy");
    IF ReservEntry2."Quantity (Base)" = 0 THEN BEGIN
    ReservEntry2.DELETE(TRUE);
    END ELSE BEGIN
    ReservEntry2.MODIFY;

    IF Item."Order Tracking Policy" = Item."Order Tracking Policy"::"Tracking & Action Msg." THEN BEGIN
    ModifyActionMessageDating(ReservEntry2);
    IF DeleteAll THEN
    ReservMgt.IssueActionMessage(ReservEntry2,FALSE,ReservEntry)
    ELSE
    ...
    प्रतिस्थापन कोड
    ...ReservEntry2.MODIFY;
    ReservEntry2."Quantity (Base)" :=
    ReservMgt.MatchSurplus(ReservEntry2,SurplusReservEntry,ReservEntry2."Quantity (Base)",NOT ReservEntry2.Positive,
    AvailabilityDate,Item."Order Tracking Policy");
    IF ReservEntry2."Quantity (Base)" = 0 THEN BEGIN
    ReservEntry2.DELETE(TRUE);
    END ELSE BEGIN

    // Add the following line.
    ReservEntry2.VALIDATE("Quantity (Base)");

    ReservEntry2.MODIFY;

    IF Item."Order Tracking Policy" = Item."Order Tracking Policy"::"Tracking & Action Msg." THEN BEGIN
    ModifyActionMessageDating(ReservEntry2);
    IF DeleteAll THEN
    ReservMgt.IssueActionMessage(ReservEntry2,FALSE,ReservEntry)
    ELSE
    ...
  2. कोई नई कुंजी जोड़ें प्रोफ़ाइल सूची तालिका (99000853) में निम्नानुसार:
    { ;Source Type,Source Order Status,Source ID,Source Batch Name,Source Ref. No.,Source Prod. Order Line,IsSupply,Due Date }
  3. एक नया स्थानीय पैरामीटर निम्नानुसार माल प्रोफ़ाइल Offsetting codeunit (99000854) में DeleteTracking फ़ंक्शन में जोड़ें:
    मौजूदा कोड
    LOCAL PROCEDURE DeleteTracking@25(VAR SKU@1000 : Record 5700;ToDate@1001 : Date);
    प्रतिस्थापन कोड
    LOCAL PROCEDURE DeleteTracking@25(VAR SKU@1000 : Record 5700;ToDate@1001 : Date;VAR SupplyInventoryProfile@1002 : Record 99000853);
  4. प्रोफ़ाइल माल Offsetting codeunit (99000854) में DeleteTracking फ़ंक्शन में एक नया स्थानीय चर जोड़ने, और फिर निम्नानुसार चर निर्दिष्ट करें:
    • नाम: ResEntryWasDelete
    • डेटा प्रकार: बूलियन
  5. प्रोफ़ाइल माल Offsetting codeunit (99000854) में DeleteTracking फ़ंक्शन में कोड निम्नानुसार परिवर्तन:
    मौजूदा कोड
    ...IF FIND('-') THEN
    REPEAT
    IF (("Reservation Status" <> "Reservation Status"::Reservation) AND
    ("Expected Receipt Date" <= ToDate) AND
    ("Shipment Date" <= ToDate)) OR
    ((Binding = Binding::"Order-to-Order") AND ("Shipment Date" <= ToDate))
    THEN BEGIN

    // Delete the following lines.
    ActionMsgEntry.SETRANGE("Reservation Entry","Entry No.");
    DELETE;
    ActionMsgEntry.DELETEALL;
    END;
    // End of the lines.

    UNTIL NEXT = 0;
    END;
    ...
    प्रतिस्थापन कोड
    ...IF FIND('-') THEN
    REPEAT
    IF (("Reservation Status" <> "Reservation Status"::Reservation) AND
    ("Expected Receipt Date" <= ToDate) AND
    ("Shipment Date" <= ToDate)) OR
    ((Binding = Binding::"Order-to-Order") AND ("Shipment Date" <= ToDate))
    THEN BEGIN

    // Add the following lines.
    ResEntryWasDeleted := TRUE;
    DELETE;
    END ELSE
    ResEntryWasDeleted := CloseTracking(ReservEntry,SupplyInventoryProfile,ToDate);

    IF ResEntryWasDeleted THEN BEGIN
    ActionMsgEntry.SETRANGE("Reservation Entry","Entry No.");
    ActionMsgEntry.DELETEALL;
    END;
    // End of the lines.

    UNTIL NEXT = 0;
    END;
    ...
  6. एक नई CloseTracking फ़ंक्शन जोड़ें प्रोफ़ाइल माल Offsetting codeunit में (99000854) निम्नानुसार:
    LOCAL PROCEDURE CloseTracking@92(ReservEntry@1000 : Record 337;VAR SupplyInventoryProfile@1001 : Record 99000853;ToDate@1002 : Date) : Boolean;VAR
    xSupplyInventoryProfile@1003 : Record 99000853;
    ReservationEngineMgt@1004 : Codeunit 99000831;
    Closed@1005 : Boolean;


    WITH ReservEntry DO BEGIN
    IF "Reservation Status" <> "Reservation Status"::Tracking THEN
    EXIT(FALSE);

    xSupplyInventoryProfile.COPY(SupplyInventoryProfile);
    Closed := FALSE;

    IF ("Expected Receipt Date" <= ToDate) AND
    ("Shipment Date" > ToDate)
    THEN BEGIN
    // tracking exists with demand in future
    SupplyInventoryProfile.SETCURRENTKEY(
    "Source Type","Source Order Status","Source ID","Source Batch Name","Source Ref. No.","Source Prod. Order Line",IsSupply);
    SupplyInventoryProfile.SETRANGE("Source Type","Source Type");
    SupplyInventoryProfile.SETRANGE("Source Order Status","Source Subtype");
    SupplyInventoryProfile.SETRANGE("Source ID","Source ID");
    SupplyInventoryProfile.SETRANGE("Source Batch Name","Source Batch Name");
    SupplyInventoryProfile.SETRANGE("Source Ref. No.","Source Ref. No.");
    SupplyInventoryProfile.SETRANGE("Source Prod. Order Line","Source Prod. Order Line");
    SupplyInventoryProfile.SETRANGE("Due Date",0D,ToDate);

    IF NOT SupplyInventoryProfile.ISEMPTY THEN BEGIN
    // demand is either deleted as well or will get Surplus status
    ReservMgt.CloseReservEntry(ReservEntry,FALSE,FALSE);
    Closed := TRUE;
    END;
    END;
    END;

    SupplyInventoryProfile.COPY(xSupplyInventoryProfile);
    EXIT(Closed);
  7. प्रोफ़ाइल माल Offsetting codeunit (99000854) में PlanItem फ़ंक्शन में कोड निम्नानुसार परिवर्तन:
    मौजूदा कोड
    ...// Preliminary clean of tracking
    IF DemandExists OR SupplyExists THEN

    // Delete the following line.
    DeleteTracking(TempSKU,ToDate);

    MatchAttributes(Supply,Demand);

    // Calculate initial inventory
    ...
    प्रतिस्थापन कोड
    ...// Preliminary clean of tracking
    IF DemandExists OR SupplyExists THEN

    // Add the following line.
    DeleteTracking(TempSKU,ToDate,Supply);

    MatchAttributes(Supply,Demand);

    // Calculate initial inventory
    ...

पूर्व-आवश्यकताएँ

आप इस हॉटफिक्स को लागू करने के लिए स्थापित निम्न उत्पादों में से कोई एक होना चाहिए:
  • Microsoft Dynamics नेविगेशन 2009 R2
  • Microsoft Dynamics नेविगेशन 2009 सर्विस पैक 1 (SP1)

निष्कासन जानकारी

आपको यह हॉटफ़िक्स नहीं निकाल सकते।

स्थिति


Microsoft ने पुष्टि की है कि यह "इन पर लागू" खण्ड में सूचीबद्ध Microsoft उत्पादों में एक समस्या है.
नोट यह एक "प्रकाशित फ़ास्ट" आलेख Microsoft समर्थन संगठन के अंदर से सीधे बनाया गया है। यहाँ शामिल जानकारी के रूप में प्रदान की गई है-emerging समस्याओं के प्रत्युत्तर में है। इसे उपलब्ध करने में गति, के परिणाम सामग्री typographical त्रुटियाँ शामिल हो सकते हैं और नोटिस के बिना किसी भी समय संशोधित किया जा सकता है। अन्य विचार के लिए उपयोग की शर्तें देखें।