Den här artikeln gäller för Microsoft Dynamics NAV för alla länder och språkversioner.
Symptom
Du kan skapa en försäljningsorder för en artikel som blockerade plötsligt inte en offert i Microsoft Dynamics-2009. När du bokför försäljningsordern visas följande felmeddelande:
Levererad kvantitet i den kopplade avropsordern får inte vara större än antalet i försäljning rad dokumenttyp = "Ramavtalet", dokumentnr '1', radnr ='tal2'.
Det här problemet uppstår i följande produkter:
-
Microsoft Dynamics NAV 2009 servicepack 1
-
Microsoft Dynamics NAV 2009 R2
Lösning
Information om snabbkorrigeringen
En snabbkorrigering är nu tillgänglig från Microsoft. Den är endast avsedd att åtgärda det problem som beskrivs i denna artikel. Använd den bara på datorer där detta problem uppstår. Snabbkorrigeringen kan komma att testas igen. Om inte störs alltför mycket av detta problem rekommenderar vi att du väntar på Nästa service pack-versionen för Microsoft Dynamics NAV 2009 eller nästa Microsoft Dynamics NAV-version som innehåller den här snabbkorrigeringen.
Obs! I särskilda fall, de avgifter som är normalt för support vara avgiftsfri om en supporttekniker för Microsoft Dynamics och relaterade produkter som bestämmer att en särskild uppdatering kan lösa ditt problem. De vanliga supportkostnaderna gäller för övriga supportfrågor och problem som inte berör den särskilda uppdateringen.Installationsinformation
Microsoft tillhandahåller programmeringsexempel endast utan garanti varken uttryckliga eller underförstådda. Detta inkluderar men är inte begränsat till, underförstådda garantier om säljbarhet eller lämplighet för ett särskilt ändamål. Den här artikeln förutsätter att du är bekant med det programmeringsspråk som demonstreras och de verktyg som används för att skapa och felsöka procedurer. Microsofts supporttekniker kan hjälpa till att förklara funktionen hos en viss procedur. De kommer inte ändra dessa exempel för att ge ytterligare funktioner eller skapa procedurer som motsvarar dina speciella behov.
Obs! Innan du installerar den här snabbkorrigeringen måste du kontrollera att alla användare i Microsoft Dynamics NAV-klienten har loggat ut. Detta omfattar tjänster för Microsoft Dynamics NAV Application Server (NAS). Du ska endast klientanvändare som är inloggad när du implementerar den här snabbkorrigeringen. Om du vill genomföra den här snabbkorrigeringen måste du ha en utvecklarlicens. Vi rekommenderar att tilldelas användarkontot i fönstret Windows-inloggningar eller i fönstret databasinloggningar "SUPER" roll-ID. Om användarkontot inte kan tilldelas "SUPER" roll-ID måste du kontrollera att användarkontot har följande behörigheter:-
Ändra behörighet för objektet ändras.
-
Körbehörighet för systemet objektet ID 5210 objekt och System objektet ID 9015
objektet.
Obs! Du har inte behörighet för datalager inte data reparation.
Kod ändras
Obs! Alltid åtgärdas testa koden i en kontrollerad miljö innan du installerar korrigeringar för produktionsdatorer.
Lös problemet så här:-
Ändra koden i egenskaper i försäljning-offert till Order kodmodul (86) enligt följande:
Befintlig kod 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); ...Ersättningskod 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); ...Befintlig kod 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; ...Ersättningskod 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; ... -
Ändra koden i egenskaper i det ramavtal för försäljning till Order kodmodul (87) enligt följande:
Befintlig kod 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); ...Ersättningskod 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); ...Befintlig kod 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 ...Ersättningskod 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 ...Befintlig kod 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); ...Ersättningskod 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); ...Befintlig kod 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) ...Ersättningskod 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) ... -
Ändra koden i egenskaper i inköp.-offert till Order kodmodul (96) enligt följande:
Befintlig kod 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); ...Ersättningskod 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);Befintlig kod 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( ...Ersättningskod 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( ... -
Ändra koden i egenskaper i ramavtal inköp. För att ordningen kodmodul (97) enligt följande:
Befintlig kod 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); ...Ersättningskod 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); ...Befintlig kod 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)" ...Ersättningskod 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)" ...Befintlig kod 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); ...Ersättningskod 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); ...Befintlig kod 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) ...Ersättningskod 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) ...
Förutsättningar
Du måste ha följande uppdatering och någon av följande produkter som har installerat den här snabbkorrigeringen:
-
Microsoft Dynamics NAV 2009 servicepack 1
-
Microsoft Dynamics NAV 2009 R2
-
2642368 "Ant. att utlevereras (bas) för objektet [Item_Number] i radnr [Line_Number] inte överstiger [antal]" felmeddelande när du försöker skapa en order från en frisläppt order i Microsoft Dynamics NAV
Information om borttagning
Du kan inte ta bort den här snabbkorrigeringen.
Status
Microsoft har bekräftat att detta är ett problem i Microsoft-produkterna som nämns i avsnittet "Gäller".
Obs! Detta är en "SNABBPUBLICERING"-artikel skapad direkt från Microsoft support-organisationen. Informationen häri tillhandahålls i befintligt skick som svar på nya problem. Till följd av hastigheten för att göra det tillgängligt kan materialet innehålla typografiska fel och kan ändras när som helst utan föregående meddelande. Se Villkoren för användningför andra överväganden.