Ця стаття відноситься до Microsoft Dynamics NAV, 2009 всі країни і всі мови.
Причини
Припустімо, що виконання планування аркуша, і ввімкнути параметр Автоматичного створення Специфікації Kit , набір елементів, які, що достатньо наявності в Microsoft Dynamics NAV 2009-R2 і Microsoft Dynamics NAV 2009 пакета оновлень 1 (SP1). Під час спроби розміщувати замовлення на продаж набір елемент, з'являється таке повідомлення про помилку:
Попереднє запис, який не існує. Визначення полів і параметрів: запис № ='Entry_Number', результат =, "Так"
Вирішення
Відомості про виправлення
Корпорація Майкрософт випустила підтримуване виправлення доступна. Однак, застосовувати лише для вирішення проблеми, описаної в цій статті. Він придатний лише для систем, які зазнають цієї конкретної проблеми. Те, що це виправлення може потребувати додаткового тестування. Таким чином, якщо ви не завдає значної, рекомендовано почекати до виходу чергового пакета оновлень Microsoft Dynamics NAV, 2009 або наступної версії Microsoft Dynamics NAV, що містить це виправлення.
Примітка. В окремих випадках оплату звернення до служби підтримки може бути скасовано якщо технічної підтримки професійного для Microsoft Dynamics і пов'язані продукти визначає телефонів служби. Плата стягується на додаткові питання і проблеми, які не пов'язані з оновленням.
Відомості про інсталяцію
Корпорація Майкрософт надає приклади програмного коду тільки для ілюстрації, без гарантій – прямих або інших. Це включає, але не обмежується, будь-яких гарантій придатності до продажу та придатності для певної мети. У цій статті припускається, що ви знайомі з мову програмування що демонструє та засоби, які використовуються для створення та налагодження процедури. Співробітники служби підтримки корпорації Майкрософт можуть пояснити функціональні особливості кожної конкретної процедури, але вони не будуть змінювати приклади для реалізації додаткових можливостей або створювати процедури на вимогу окремих користувачів.
Примітка. Перш ніж інсталювати це виправлення, переконайтеся, що усі користувачі Microsoft Navision-клієнт відключився системи. Пакет оновлень містить Microsoft Navision застосунок служби (NAS) клієнта користувачів. Ви повинні тільки клієнт користувача, який увійшов до системи, під час виконання цього виправлення. Щоб застосувати це виправлення, потрібно мати ліцензію для розробників. Корпорація Майкрософт рекомендує, що обліковий запис користувача Windows входи вікна або у вікні бази даних входи призначити "Супер" роль ID. Якщо обліковий запис користувача не призначено роль ID "Супер", необхідно переконатися, що обліковий запис користувача, має такі дозволи:-
Змінити дозвіл об'єкт, який буде змінити.
-
Права для виконання системи об'єкт з Ідентифікатором 5210 об'єкт а також системи об'єкт з Ідентифікатором 9015 об'єкта.
Примітка. Маєте відповідних прав до сховища даних, якщо у вас є для виконання даних відновлення не потрібно.
Зміни коду
Примітка. Завжди тест код вирішення в середовищі контрольовані перед інсталяцією розглянутого виправлення виробництва комп'ютерів.
Щоб вирішити цю проблему, таким чином змінити код DemandtoInvProfile функції в інвентарний список профілів, Взаємозалік codeUnit (99000854): Примітка: 26/10/11 був незначні зміни в цій статті, щоб переконатися у тексті коду з код, який було опубліковано в для NAV 5.0SP1. Функції не зазнав змін. Певних рядків, які змінено, можна в розділі "Додати" нового коду;Рядок: InventoryProfile. " Лінія №": = LineNo; змінити на: InventoryProfile. " Лінія №": = NextLineNo;
Лінія: LineNo: = LineNo 1; було видалено.Наявний код
...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; ...
Заміна код
...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; ...
Попередні вимоги
Ви повинні мати одну з наведених нижче продуктів, щоб застосувати це виправлення:
-
Microsoft Dynamics NAV 2009 R2
-
Microsoft Dynamics NAV 2009 пакет оновлень 1 для
Відомості про видалення
Це виправлення не можна видалити.
Стан
Корпорація Майкрософт підтвердила існування цієї неполадки у продуктах Майкрософт, перелічених у розділі "Застосовується до".
Примітка. Це "Швидка публікація" статті, надана службою підтримки корпорації Майкрософт. Відомості в цій статті надано без змін у відповідь на повідомлення про проблеми. З огляду на швидкість публікації матеріали можуть містити орфографічні помилки. Їх може бути змінено в будь-який час без повідомлення. Щоб отримати додаткові відомості, див. Умови використання.