Applies ToDynamics NAV 2009 Service Pack 1 Microsoft Dynamics NAV 2009 R2

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

Príznaky

Môžete vytvoriť predajnej objednávky blokované položky sa z predaja citát v Microsoft Dynamics 2009 neočakávane. Pri účtovaní predajnej objednávky, zobrazí nasledujúce chybové hlásenie:

Množstvo dodané v priradená hromadná objednávka nesmie byť väčšie množstvo predaja typ dokumentu linky = "Hromadná objednávka", číslo dokladu "číslo 1", číslo riadka = "číslo 2".

Tento problém sa vyskytuje v nasledovných produktov:

  • Microsoft Dynamics NAV 2009 Service Pack 1

  • Microsoft Dynamics NAV 2009 R2

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 môžu vysvetliť fungovanie konkrétneho postupu. Ale nemôžu tieto príklady poskytovať pridanú funkčnosť alebo konštrukčné procedúry zohľadňujúce vaše konkrétne požiadavky.Poznámka: Pred inštaláciou tejto rýchlej opravy, kontrola všetkých používateľov klienta Microsoft Dynamics NAV systém. To zahŕňa služby Microsoft Dynamics NAV aplikácie servera (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účame, aby používateľského konta 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 9015objekt.

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, postupujte nasledovne:

  1. Zmeniť kód predaja ponuky na objednávku procedúra (86):Nahradenie kód 1

    ...Opp@1004 : Record 5092;              OpportunityEntry@1006 : Record 5093;              TempOpportunityEntry@1005 : TEMPORARY Record 5093;              Cust@1008 : Record 18;            BEGIN              TESTFIELD("Document Type","Document Type"::Quote);              Cust.GET("Sell-to Customer No.");              Cust.CheckBlockedCustOnDocs(Cust,"Document Type"::Order,TRUE,FALSE);...

    Nahradenie kód 2

    ...Opp@1004 : Record 5092;              OpportunityEntry@1006 : Record 5093;              TempOpportunityEntry@1005 : TEMPORARY Record 5093;              Cust@1008 : Record 18;// Add the following line.          Item@1010 : Record 27; // End of the added line.            BEGIN              TESTFIELD("Document Type","Document Type"::Quote);              Cust.GET("Sell-to Customer No.");              Cust.CheckBlockedCustOnDocs(Cust,"Document Type"::Order,TRUE,FALSE);...

    Existujúci kód 2

    ...SalesQuoteLine.SETRANGE(Type,SalesQuoteLine.Type::Item);              SalesQuoteLine.SETFILTER("No.",'<>%1','');              IF SalesQuoteLine.FINDSET THEN                REPEAT                  IF (SalesQuoteLine."Outstanding Quantity" > 0) THEN BEGIN                    SalesLine := SalesQuoteLine;                    SalesLine.VALIDATE("Reserved Qty. (Base)",0);                    SalesLine."Line No." := 0;...

    Nahradenie kód 2

    ...SalesQuoteLine.SETRANGE(Type,SalesQuoteLine.Type::Item);              SalesQuoteLine.SETFILTER("No.",'<>%1','');              IF SalesQuoteLine.FINDSET THEN                REPEAT                 IF Item.GET(SalesQuoteLine."No.") THEN         //add line// Add the following line.               Item.TESTFIELD(Blocked,FALSE);  // End of the added line.                  IF (SalesQuoteLine."Outstanding Quantity" > 0) THEN BEGIN                    SalesLine := SalesQuoteLine;                    SalesLine.VALIDATE("Reserved Qty. (Base)",0);                    SalesLine."Line No." := 0;...
  2. Zmeniť kód v hromadnej predajnej objednávky na objednávku procedúra (87):Nahradenie kód 1

    ...Cust@1001 : Record 18;              TempSalesLine@1002 : TEMPORARY Record 37;              Reservation@1005 : Form 498;              PrepmtMgt@1004 : Codeunit 441;            BEGIN              TESTFIELD("Document Type","Document Type"::"Blanket Order");              Cust.GET("Sell-to Customer No.");              Cust.CheckBlockedCustOnDocs(Cust,"Document Type"::Order,TRUE,FALSE);...

    Nahradenie kód 1

    ...Cust@1001 : Record 18;              TempSalesLine@1002 : TEMPORARY Record 37;              Reservation@1005 : Form 498;              PrepmtMgt@1004 : Codeunit 441;// Add the following line.              Item@1006 : Record 27;                  // End of the added line.            BEGIN              TESTFIELD("Document Type","Document Type"::"Blanket Order");              Cust.GET("Sell-to Customer No.");              Cust.CheckBlockedCustOnDocs(Cust,"Document Type"::Order,TRUE,FALSE);...

    Existujúci kód 2

    ...SalesLine.SETRANGE("Blanket Order Line No.",BlanketOrderSalesLine."Line No.");                  QuantityOnOrders := 0;                  IF SalesLine.FINDSET THEN                    REPEAT                      IF SalesLine."Document Type" IN                          [SalesLine."Document Type"::"Return Order",                           SalesLine."Document Type"::"Credit Memo"]                      THEN...

    Nahradenie kód 2

    ...SalesLine.SETRANGE("Blanket Order Line No.",BlanketOrderSalesLine."Line No.");                  QuantityOnOrders := 0;                  IF SalesLine.FINDSET THEN                    REPEAT// Add the following lines.                      IF Item.GET(SalesLine."No.") THEN                                             Item.TESTFIELD(Blocked,FALSE);// End of the added lines.                                        IF SalesLine."Document Type" IN                          [SalesLine."Document Type"::"Return Order",                           SalesLine."Document Type"::"Credit Memo"]                      THEN...

    Existujúci kód 3

    ...TempSalesLine.DELETEALL;                REPEAT                  SalesLine.SETCURRENTKEY("Document Type","Blanket Order No.","Blanket Order Line No.");                  SalesLine.SETRANGE("Blanket Order No.",BlanketOrderSalesLine."Document No.");                  SalesLine.SETRANGE("Blanket Order Line No.",BlanketOrderSalesLine."Line No.");// Delete the following lines.                  SalesLine.SETFILTER(                                           "Document Type",'<>%1 & <>%2',SalesLine."Document Type"::Invoice,SalesLine."Document Type"::"Credit Memo");// End of the deleted lines.                  QuantityOnOrders := 0;                  IF SalesLine.FINDSET THEN                    REPEAT                      IF Item.GET(SalesLine."No.") THEN                        Item.TESTFIELD(Blocked,FALSE);...

    Nahradenie kód 3

    ...TempSalesLine.DELETEALL;                REPEAT                  SalesLine.SETCURRENTKEY("Document Type","Blanket Order No.","Blanket Order Line No.");                  SalesLine.SETRANGE("Blanket Order No.",BlanketOrderSalesLine."Document No.");                  SalesLine.SETRANGE("Blanket Order Line No.",BlanketOrderSalesLine."Line No.");                  QuantityOnOrders := 0;                  IF SalesLine.FINDSET THEN                    REPEAT                      IF Item.GET(SalesLine."No.") THEN                        Item.TESTFIELD(Blocked,FALSE);...

    Existujúci kód 4

    ...QuantityOnOrders := 0;                  IF SalesLine.FINDSET THEN                    REPEAT                      IF Item.GET(SalesLine."No.") THEN                        Item.TESTFIELD(Blocked,FALSE);// Delete the following lines.                      IF SalesLine."Document Type" = SalesLine."Document Type"::"Return Order" THEN                            QuantityOnOrders := QuantityOnOrders - SalesLine."Outstanding Qty. (Base)"                                 ELSE                                                                                                                                               //Remove line                              QuantityOnOrders := QuantityOnOrders + SalesLine."Outstanding Qty. (Base)";        // End of the deleted lines.                    UNTIL SalesLine.NEXT = 0;                  IF (ABS(BlanketOrderSalesLine."Qty. to Ship (Base)" + QuantityOnOrders +                          BlanketOrderSalesLine."Qty. Shipped (Base)") >                      ABS(BlanketOrderSalesLine."Quantity (Base)")) OR                     (BlanketOrderSalesLine."Quantity (Base)" * BlanketOrderSalesLine."Outstanding Qty. (Base)" < 0)...

    Nahradenie kód 4

    ...QuantityOnOrders := 0;                  IF SalesLine.FINDSET THEN                    REPEAT                      IF Item.GET(SalesLine."No.") THEN                        Item.TESTFIELD(Blocked,FALSE);// Add the following lines.                      IF (SalesLine."Document Type" = SalesLine."Document Type"::"Return Order") OR                         ((SalesLine."Document Type" = SalesLine."Document Type"::"Credit Memo") AND                          (SalesLine."Return Receipt No." = ''))                      THEN                        QuantityOnOrders := QuantityOnOrders - SalesLine."Outstanding Qty. (Base)"                      ELSE                        IF (SalesLine."Document Type" = SalesLine."Document Type"::Order) OR                           ((SalesLine."Document Type" = SalesLine."Document Type"::Invoice) AND                            (SalesLine."Shipment No." = ''))                        THEN                          QuantityOnOrders := QuantityOnOrders + SalesLine."Outstanding Qty. (Base)";// End of the added lines.                    UNTIL SalesLine.NEXT = 0;                  IF (ABS(BlanketOrderSalesLine."Qty. to Ship (Base)" + QuantityOnOrders +                          BlanketOrderSalesLine."Qty. Shipped (Base)") >                      ABS(BlanketOrderSalesLine."Quantity (Base)")) OR                     (BlanketOrderSalesLine."Quantity (Base)" * BlanketOrderSalesLine."Outstanding Qty. (Base)" < 0)...
  3. Zmena kódu vo vlastnostiach v nákupné.-ponuka na objednávku procedúra (96) takto:Nahradenie kód 1

    ...OldPurchCommentLine@1001 : Record 43;              FromDocDim@1000 : Record 357;              ToDocDim@1003 : Record 357;              Vend@1002 : Record 23;            BEGIN              TESTFIELD("Document Type","Document Type"::Quote);              Vend.GET("Buy-from Vendor No.");              Vend.CheckBlockedVendOnDocs(Vend,FALSE);...

    Nahradenie kód 1

    ...OldPurchCommentLine@1001 : Record 43;              FromDocDim@1000 : Record 357;              ToDocDim@1003 : Record 357;              Vend@1002 : Record 23;// Add the following line.              Item@1004 : Record 27;           // End of the added line.            BEGIN              TESTFIELD("Document Type","Document Type"::Quote);              Vend.GET("Buy-from Vendor No.");              Vend.CheckBlockedVendOnDocs(Vend,FALSE);

    Existujúci kód 2

    ...ToDocDim.SETRANGE("Table ID",DATABASE::"Purchase Line");              IF PurchQuoteLine.FINDSET THEN                REPEAT                  PurchOrderLine := PurchQuoteLine;                  PurchOrderLine."Document Type" := PurchOrderHeader."Document Type";                  PurchOrderLine."Document No." := PurchOrderHeader."No.";                  ReservePurchLine.TransferPurchLineToPurchLine(...

    Nahradenie kód 2

    ...ToDocDim.SETRANGE("Table ID",DATABASE::"Purchase Line");              IF PurchQuoteLine.FINDSET THEN                REPEAT// Add the following lines.                  IF Item.GET(PurchQuoteLine."No.") THEN                       Item.TESTFIELD(Blocked,FALSE);                 // End of the added lines.                  PurchOrderLine := PurchQuoteLine;                  PurchOrderLine."Document Type" := PurchOrderHeader."Document Type";                  PurchOrderLine."Document No." := PurchOrderHeader."No.";                  ReservePurchLine.TransferPurchLineToPurchLine(...
  4. Zmeňte kód v hromadných nákupné. Aby objednávka procedúra (97) takto:Nahradenie kód 1

    ...FromDocDim@1000 : Record 357;              ToDocDim@1002 : Record 357;              Vend@1001 : Record 23;              PrepmtMgt@1003 : Codeunit 441;            BEGIN              TESTFIELD("Document Type","Document Type"::"Blanket Order");              Vend.GET("Buy-from Vendor No.");              Vend.CheckBlockedVendOnDocs(Vend,FALSE);...

    Nahradenie kód 1

    ...FromDocDim@1000 : Record 357;              ToDocDim@1002 : Record 357;              Vend@1001 : Record 23;              PrepmtMgt@1003 : Codeunit 441;// Add the following line.              Item@1004 : Record 27;                     // End of the added line.            BEGIN              TESTFIELD("Document Type","Document Type"::"Blanket Order");              Vend.GET("Buy-from Vendor No.");              Vend.CheckBlockedVendOnDocs(Vend,FALSE);...

    Existujúci kód 2

    ...PurchLine.SETRANGE("Blanket Order Line No.",PurchBlanketOrderLine."Line No.");                  QuantityOnOrders := 0;                  IF PurchLine.FINDSET THEN                    REPEAT                      IF PurchLine."Document Type" IN                          [PurchLine."Document Type"::"Return Order",                           PurchLine."Document Type"::"Credit Memo"] THEN                        QuantityOnOrders := QuantityOnOrders - PurchLine."Outstanding Qty. (Base)"...

    Nahradenie kód 2

    ...PurchLine.SETRANGE("Blanket Order Line No.",PurchBlanketOrderLine."Line No.");                  QuantityOnOrders := 0;                  IF PurchLine.FINDSET THEN                    REPEAT// Add the following lines.                      IF Item.GET(PurchLine."No.") THEN                            Item.TESTFIELD(Blocked,FALSE);       // End of the added lines.                      IF PurchLine."Document Type" IN                          [PurchLine."Document Type"::"Return Order",                           PurchLine."Document Type"::"Credit Memo"] THEN                        QuantityOnOrders := QuantityOnOrders - PurchLine."Outstanding Qty. (Base)"...

    Existujúci kód 3

    ...IF PurchBlanketOrderLine.FINDSET THEN                REPEAT                  PurchLine.SETCURRENTKEY("Document Type","Blanket Order No.","Blanket Order Line No.");                  PurchLine.SETRANGE("Blanket Order No.",PurchBlanketOrderLine."Document No.");                  PurchLine.SETRANGE("Blanket Order Line No.",PurchBlanketOrderLine."Line No.");// Delete the following lines.                  PurchLine.SETFILTER(                    "Document Type",'<>%1 & <>%2',PurchLine."Document Type"::Invoice,PurchLine."Document Type"::"Credit Memo");// End of the deleted lines.                  QuantityOnOrders := 0;                  IF PurchLine.FINDSET THEN                    REPEAT                      IF Item.GET(PurchLine."No.") THEN                        Item.TESTFIELD(Blocked,FALSE);...

    Nahradenie kód 3

    ...IF PurchBlanketOrderLine.FINDSET THEN                REPEAT                  PurchLine.SETCURRENTKEY("Document Type","Blanket Order No.","Blanket Order Line No.");                  PurchLine.SETRANGE("Blanket Order No.",PurchBlanketOrderLine."Document No.");                  PurchLine.SETRANGE("Blanket Order Line No.",PurchBlanketOrderLine."Line No.");                  QuantityOnOrders := 0;                  IF PurchLine.FINDSET THEN                    REPEAT                      IF Item.GET(PurchLine."No.") THEN                        Item.TESTFIELD(Blocked,FALSE);...

    Existujúci kód 4

    ...QuantityOnOrders := 0;                  IF PurchLine.FINDSET THEN                    REPEAT                      IF Item.GET(PurchLine."No.") THEN                        Item.TESTFIELD(Blocked,FALSE);// Delete the following lines.                      IF PurchLine."Document Type" = PurchLine."Document Type"::"Return Order" THEN                        QuantityOnOrders := QuantityOnOrders - PurchLine."Outstanding Qty. (Base)"                      ELSE                        QuantityOnOrders := QuantityOnOrders + PurchLine."Outstanding Qty. (Base)";// End of the deleted lines.                    UNTIL PurchLine.NEXT = 0;                  IF (ABS(PurchBlanketOrderLine."Qty. to Receive (Base)" + QuantityOnOrders +                          PurchBlanketOrderLine."Qty. Received (Base)") >                      ABS(PurchBlanketOrderLine."Quantity (Base)")) OR                     (PurchBlanketOrderLine."Quantity (Base)" * PurchBlanketOrderLine."Outstanding Qty. (Base)" < 0)...

    Nahradenie kód 4

    ...QuantityOnOrders := 0;                  IF PurchLine.FINDSET THEN                    REPEAT                      IF Item.GET(PurchLine."No.") THEN                        Item.TESTFIELD(Blocked,FALSE);// Add the following lines.                      IF (PurchLine."Document Type" = PurchLine."Document Type"::"Return Order") OR                         ((PurchLine."Document Type" = PurchLine."Document Type"::"Credit Memo") AND                          (PurchLine."Return Shipment No." = ''))                      THEN                        QuantityOnOrders := QuantityOnOrders - PurchLine."Outstanding Qty. (Base)"                      ELSE                        IF (PurchLine."Document Type" = PurchLine."Document Type"::Order) OR                           ((PurchLine."Document Type" = PurchLine."Document Type"::Invoice) AND                            (PurchLine."Receipt No." = ''))                        THEN                          QuantityOnOrders := QuantityOnOrders + PurchLine."Outstanding Qty. (Base)";// End of the added lines.                    UNTIL PurchLine.NEXT = 0;                  IF (ABS(PurchBlanketOrderLine."Qty. to Receive (Base)" + QuantityOnOrders +                          PurchBlanketOrderLine."Qty. Received (Base)") >                      ABS(PurchBlanketOrderLine."Quantity (Base)")) OR                     (PurchBlanketOrderLine."Quantity (Base)" * PurchBlanketOrderLine."Outstanding Qty. (Base)" < 0)...

Požiadavky

Musíte mať nasledujúce aktualizácie a jedno z nasledovných produktov nainštalovaný chcete použiť túto rýchlu opravu:

  • Microsoft Dynamics NAV 2009 Service Pack 1

  • Microsoft Dynamics NAV 2009 R2

  • 2642368 "Množstvo na dodanie (základ) tovaru [Item_Number] v riadku číslo [Line_Number] nemôže byť viac ako [číslo]" chybové hlásenie pri pokuse o vytvorenie objednávky z hromadnej objednávky v Microsoft Dynamics NAV

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žívaniaz 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.