Artikel ini berlaku untuk Microsoft Dynamics NAV 2009 untuk semua negara dan semua bahasa lokal.
Gejala
Misalnya Anda menjalankan lembar kerja perencanaan dan Anda mengaktifkan setelan Otomatis membangun Kit BOM Kit item yang memiliki cukup saham di Microsoft Dynamics NAV 2009 R2 dengan Microsoft Dynamics NAV 2009 Paket Layanan 1 (SP1). Ketika Anda mencoba untuk mengirimkan pesanan penjualan item Kit, Anda menerima pesan galat berikut:
Tidak ada entri reservasi. Bidang identifikasi dan nilai: No entri ='Entry_Number', positif = 'Ya'
Pemecahan masalah
Informasi Hotfix
Sekarang tersedia hotfix yang didukung dari Microsoft. Namun, hanya ditujukan untuk memperbaiki masalah yang dijelaskan di artikel ini. Terapkan hanya ke sistem yang mengalami masalah khusus ini. Perbaikan terbaru ini dapat menerima pengujian tambahan. Oleh karena itu, jika Anda tidak terlalu dipengaruhi oleh masalah ini, kami sarankan Anda menunggu paket layanan Microsoft Dynamics NAV 2009 atau versi Microsoft Dynamics NAV berikutnya yang berisi perbaikan terbaru ini.
Catatan Dalam kasus tertentu, biaya yang biasanya diadakan untuk panggilan mungkin dibatalkan apabila profesional dukungan teknis untuk Microsoft Dynamics dan produk-produk terkait dukungan menentukan bahwa pembaruan khusus akan memecahkan masalah Anda. Biaya dukungan biasa akan berlaku untuk pertanyaan dan masalah yang tidak termasuk pada pembaruan tertentu yang dimaksud dukungan tambahan.
Informasi penginstalan
Microsoft menyediakan contoh pemrogaman hanya untuk ilustrasi, tanpa garansi baik tersurat maupun tersirat. Ini mencakup, namun tidak terbatas pada, garansi yang tersirat dapat diperjualbelikan atau kesesuaian untuk tujuan tertentu. Artikel ini menganggap bahwa Anda sudah terbiasa dengan bahasa pemrograman yang ditunjukkan dan terbiasa dengan alat-alat yang digunakan untuk membuat dan prosedur debug. Teknisi dukungan Microsoft dapat membantu menjelaskan fungsionalitas prosedur tertentu, namun mereka tidak akan mengubah contoh tersebut untuk memberikan fungsionalitas tambahan atau menyusun prosedur untuk memenuhi persyaratan khusus Anda.
Catatan Sebelum Anda menginstal perbaikan terbaru ini, verifikasi bahwa semua pengguna klien Microsoft Navision log off sistem. Ini termasuk Microsoft Navision aplikasi Layanan (NAS) klien pengguna. Anda harus klien hanya pengguna yang masuk saat Anda menerapkan perbaikan terbaru ini. Untuk menerapkan hotfix ini, Anda harus memiliki lisensi pengembang. Kami menyarankan bahwa akun pengguna di jendela login Windows atau jendela login Database ditetapkan id peran "SUPER" Jika account pengguna tidak dapat menetapkan ID peran "SUPER", Anda harus memverifikasi bahwa account pengguna yang memiliki izin berikut ini:-
Ubah izin untuk objek yang Anda akan berubah.
-
Izin eksekusi untuk objek sistem objek ID 5210 dan sistem objek ID 9015 objek.
Catatan Anda tidak harus memiliki hak untuk penyimpanan data kecuali jika Anda harus melakukan perbaikan data.
Perubahan kode
Catatan Selalu menguji kode perbaikan di lingkungan yang dikontrol sebelum menerapkan perbaikan untuk komputer produksi.
Untuk mengatasi masalah ini, Ubah kode di fungsi DemandtoInvProfile dalam inventaris profil offset codeUnit (99000854) sebagai berikut: Catatan: 26/10/11 ada sedikit perubahan ke KB ini membuat inline kode dengan kode yang diterbitkan untuk NAV 5.0SP1. Fungsionalitas tidak berubah. Baris tertentu yang berubah di bagian "Add" kode penggantian;Baris: InventoryProfile. " Nomor baris": = LineNo;Â Ubah ke: InventoryProfile. " Nomor baris": = NextLineNo;
Baris: LineNo: = LineNo + 1; dihapus.Kode yang ada
...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; ...
Penggantian kode
...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; ...
Prasyarat
Anda harus memiliki salah satu produk berikut ini diinstal untuk menerapkan perbaikan terbaru ini:
-
Microsoft Dynamics NAV 2009 R2
-
Microsoft Dynamics NAV 2009 Service Pack 1
Informasi penghapusan
Anda tidak dapat menghapus hotfix ini.
Status
Microsoft telah memastikan bahwa ini merupakan masalah di dalam produk Microsoft sebagaimana tercantum di bagian "Berlaku untuk".
Catatan Ini adalah artikel "Penerbitan cepat" dibuat langsung dari dalam organisasi dukungan Microsoft. Informasi yang terkandung di dalamnya disediakan sebagai tanggapan masalah yang muncul. Sebagai akibat dari kecepatan untuk menjadikannya tersedia, materi dapat mengandung kesalahan ketik dan dapat direvisi setiap saat tanpa pemberitahuan. Lihat Ketentuan untuk pertimbangan lainnya.