zoukankan      html  css  js  c++  java
  • MTO企业可能会有的需求

    问题描述
    按单生产的企业,销售订单是一切的源头,在后续的生产和采购过程中都需要看到是为哪张销售订单,哪个客户生产或者采购的。
    客户采购的是A产品,A产品又由B和C组成,而B,C又需要生产,在生产B和C的时候工厂也需要知道为哪张销售订单生产的以及其关联的销售订单上对B和C的具体要求。AX目前的数据结构只能看到最顶级的BOM上看到关联的销售订单,如果B,C想看到就要一级级往上查这很不方便。
    解决方案
    给计划生产订单和计划采购订单添加一个SalesLineRecId字段,让其记录SalesLine的RecId.写一个类MTOSolution,通过递归得到每一张计划生产订单和计划采购订单关联的SalesLine的RecId,并更新到SalesLineRecId中。
    public static void UpdateReqTransPoS()
    {
        
    /*
            在将每张计划生产工单都加上销售订单行的RecId
        
    */


        ReqPo               reqPo;
        ReqTrans            reqTrans;
        ReqTransCov         reqTransCov;
        ;

        ttsbegin;
        
    while select forupdate SalesLineRecId from reqPo
            where reqPo.ReqPlanId 
    == 'MPS'
                join Qty,RefType,InventTransId,RefId from reqTrans
            where ReqPO.RefType 
    == reqTrans.RefType &&
                  ReqPO.RefId   
    == reqTrans.RefId &&
                  ReqPO.ReqPlanId 
    == reqTrans.ReqPlanId &&
                  reqTrans.IsDerivedDirectly 
    == NoYes::No
                  
    {
                        
    if(!reqPo.SalesLineRecId)
                        
    {

                            reqPo.SalesLineRecId 
    = MTOSolution::GetSalesLineRecId(reqTrans);
                            reqPo.doUpdate();
                        }

                  }

        ttscommit;

    }

    该方法调用GetSalesLineRecId方法得到SalesLine的RecId
    static RecId GetSalesLineRecId(ReqTrans _reqTrans)
    {
        SalesLine salesLine;
        ReqTrans reqTrans;
        ReqTransCov reqTransCov;
        ;

        
    if(!_reqTrans)
            
    return 0;

        
    //寻找到销售订单,返回销售订单行的RecId
        if(_reqTrans.RefType == ReqRefType::Sales)
            
    return (select recId from SalesLine where SalesLine.InventTransId == _reqTrans.InventTransId).recId;

        
    //如果是计划生产订单(计划采购订单),则找到其上级
        if(_reqTrans.RefType == ReqRefType::BOMPlannedOrder ||
           _reqTrans.RefType 
    == ReqRefType::ItemPlannedOrder)
        
    {
            
    if(_reqTrans.Qty>=0)
            
    {
                select Qty,RefType,InventTransId,RefId from reqTrans
                join 
    * from reqTransCov
                where reqTrans.RecId 
    == reqTransCov.IssueRecId && reqTransCov.ReceiptRecId == _reqTrans.RecId;
            }

            
    else
            
    {
                select Qty,RefType,InventTransId,RefId from reqTrans
                join 
    * from reqTransCov
                where reqTrans.RecId 
    == reqTransCov.ReceiptRecId && reqTransCov.IssueRecId == _reqTrans.RecId;


            }

        }

        
    else              //同上
        if(_reqTrans.RefType == ReqRefType::BOMLine)
        
    {
            select Qty,RefType,InventTransId,RefId from reqTrans
            where reqTrans.RefType 
    == ReqRefType::BOMPlannedOrder &&
                  reqTrans.RefId 
    == _ReqTrans.RefId;
        }


        
    return MTOSolution::GetSalesLineRecId(reqTrans);

    }
    在类ReqCalcScheduleItemTable的Main方法的最后调用MTOSolution的UpdateReqTransPoS静态方法。
    在接下来的生产订单和采购订单中也要看到相应的记录,可以在ProdTable和PurchLine中也添加SalesLineRecId字段,并在各自表的initFromReqPO方法中添加如下代码:
    this.SalesLineRecId         = _reqPo.SalesLineRecId;
    这样就传递到下一层了。
  • 相关阅读:
    c# 扩展方法奇思妙用
    AnkhSVN的自动加锁
    C#数组学习
    同一IP下多端口网站共享cookie的问题
    瞎子摸象销售开票(一)
    瞎子摸象年结
    配置WSS3.0搜索功能的步骤
    瞎子摸象销售开票(二)
    瞎子摸象汇兑损益
    ajax+php鼠标拖动层至任意位置并实时保存
  • 原文地址:https://www.cnblogs.com/Farseer1215/p/826099.html
Copyright © 2011-2022 走看看