本文适用于 Microsoft Dynamics 导航对于所有语言的区域设置。
症状
顺序规划函数计算不正确的"订购数量"建议当您在 Microsoft Dynamics NAV.使用单生成环境如果您使用多级物料清单的物料 (清单 BOM),将发生此问题。
下列产品中发生此问题︰-
Microsoft Dynamics NAV 2009 R2
-
Microsoft Dynamics NAV 2009 Service Pack 1 (SP1)
-
Microsoft Dynamics 导航 2009
-
Microsoft Dynamics 导航 5.0 版 Service Pack 1 (SP1)
原因
系统将使用递归函数总是更改 (物料清单创建"树"的一些项目可能发生一个或多个时间) 找到的项的数量。但是,这是不正确的行为,因为已更新项的所有子项应被删除或更新。
解决方案
修补程序信息
受支持的修补程序现已从 Microsoft 推出。然而,它仅用于纠正本文中描述的问题。它仅应用于正经历此特定问题的系统。此修补程序可能会接受进一步的测试。因此,如果这个问题没有对您造成严重的影响,我们建议您等待下一个 Microsoft Dynamics 导航 2009 服务包 或包含此修复程序的下一步的 Microsoft Dynamics 导航版本。
注意: 在特殊情况下,可免收的支持电话,可免收如果技术支持专业人员对 Microsoft Dynamics 和相关的产品的费用确定某个特定的更新能够解决您的问题。照常收取支持费用将应用于其他支持问题和对于特定更新无法解决的问题。
安装信息
Microsoft 提供的编程示例仅用于说明,没有任何明示或暗示的担保。这包括但不限于适销性或特定用途适用性的暗示担保。本文假定您熟悉所演示的编程语言和用于创建和调试过程的工具。Microsoft 的支持工程师可以帮助解释某个特定过程的功能,但是他们不会修改这些示例以提供额外的功能或构建过程以满足您的特定要求。
注意:安装此修复程序之前,请验证所有 Microsoft Navision 客户端用户都注销系统。这包括 Microsoft Navision 应用程序服务 (NAS) 客户端的用户。要实现此修补程序时,在登录的唯一客户端用户。 若要实现此修补程序,必须使用开发人员许可证。 我们建议在 Windows 登录窗口或数据库登录窗口中的用户帐户将分配该"超级"角色 id。如果不能将用户帐户分配成"超级"角色 ID,则必须验证用户帐户具有下列权限:-
您将更改该对象的修改权限。
-
为系统对象 ID ™ 5210对象和系统对象 ID 9015对象的 Execute 权限。
注意:您不需要具有对数据存储区的权限,除非您需要执行数据修复。
代码更改
注意:始终测试代码修复在受控环境中应用之前与您的生产计算机的修补程序。
若要解决此问题,请执行以下步骤:-
创建本地函数UpdateRelatedComponent codeunit (99000809):
...LOCAL PROCEDURE UpdateRelatedComponent@15(ParentReqLine@1000 : Record 246);
WITH PlanningComponent DO BEGIN SETCURRENTKEY("Worksheet Template Name","Worksheet Batch Name","Worksheet Line No.","Item No."); SETRANGE("Worksheet Line No.",ParentReqLine."Line No."); SETFILTER("Item No.",'<>%1',''); SETFILTER("Expected Quantity",'<>0'); SETFILTER("Planning Level Code",'<>0'); IF FIND('-') THEN REPEAT IF LineHasBeenCreated(ChildReqLine,PlanningComponent) THEN BEGIN UpdateRelatedComponent(ChildReqLine); IF ChildReqLine.Quantity <> "Expected Quantity" THEN BEGIN // qty has to be updated, there is a new need of component ChildReqLine.BlockDynamicTracking(Blocked); ChildReqLine.VALIDATE(Quantity,ChildReqLine.Quantity - "Expected Quantity"); ChildReqLine.MODIFY; // updating qty of component for parent VALIDATE("Quantity per","Quantity per"); MODIFY; END ELSE // line will be recreated ChildReqLine.DELETE(TRUE); END; UNTIL NEXT = 0; END; ...-
名称︰ PlanningComponent; 数据类型︰ 记录 (99000829)
-
名称︰ ChildReqLine;数据类型︰ 记录 (246)
-
-
创建本地函数LineHasBeenCreated codeunit (99000829):
...LOCAL PROCEDURE LineHasBeenCreated@18(VAR ChildReqLine@1000 : Record 246;PlanningComponent@1001 : Record 99000829) : Boolean;
WITH ChildReqLine DO BEGIN SETCURRENTKEY("Worksheet Template Name","Journal Batch Name",Type,"No."); SETRANGE("Worksheet Template Name",PlanningComponent."Worksheet Template Name"); SETRANGE("Journal Batch Name",PlanningComponent."Worksheet Batch Name"); SETRANGE(Type,Type::Item); SETRANGE("No.",PlanningComponent."Item No."); SETRANGE("Variant Code",PlanningComponent."Variant Code"); SETRANGE("Ref. Order Type","Ref. Order Type"::"Prod. Order"); SETRANGE("Ref. Order Status",PlanningComponent."Ref. Order Status"); SETRANGE("Ref. Order No.",PlanningComponent."Ref. Order No."); SETFILTER("Planning Level",'>%1',0); EXIT(FINDFIRST); END; ... -
更改 codeunit (99000809) 的InsertPlanningLine函数中的代码,如下所示︰
现有代码... IF ReqLine2."Planning Level" < ReqLine."Planning Level" THEN
ReqLine2."Planning Level" := ReqLine."Planning Level"; ReqLine2.MODIFY; ...替换代码
... IF ReqLine2."Planning Level" <ReqLine."Planning Level" THEN
ReqLine2."Planning Level" := ReqLine."Planning Level"; // the ReqLine2 can have children which has to be delete or updated // Add the following line. UpdateRelatedComponent(ReqLine2); ReqLine2.MODIFY; ...
系统必备组件
您必须具有要应用此修补程序的安装以下产品之一︰
-
Microsoft Dynamics NAV 2009 R2
-
Microsoft Dynamics NAV 2009 Service Pack 1 (SP1)
-
Microsoft Dynamics 导航 2009
-
Microsoft Dynamics 导航 5.0 版 Service Pack 1 (SP1)
删除信息
您不能删除此修补程序。
状态
Microsoft 已经确认这是“适用于”一节中列出的 Microsoft 产品中的问题。
注意:这是直接从创建 Microsoft 支持部门内的"快速发布"的文章。此处包含的信息是作为为了响应新出现的问题而提供的。由于以使其可用的速度,而材料可能包含印刷错误,恕不另行通知,随时可能进行修订。其他考虑因素,请参阅使用条款。