DSO数据激活后数据为0

本文探讨了一个数据加载到DSO后字段出现意外为0的情况,并通过设置EndRoutine中的字段为常量解决了问题。通过转换规则的调整和EndRoutine的代码实现,确保了数据的一致性和准确性。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

        今天遇到一个问题,数据加载到DSO,激活后发现有个字段为0,这个字段明明是是不可能为0的呀,有点想不通。

        先再现形问题,用一个简单的情形来模拟:

        我有一个DSO,没什么特别的,如下图

      

      在转换规则中,IK_RQTY不是从数据源映射过来的,而是我到时在End Routine中写ABAP代码而获得的。

    

     在IK_RQTY的Rule Detail中再看看,我设的了No Transformation,因为我不用到任何转换嘛,所以是No Transformation,我是这么想的。

   

   而在End Routine,我是写以下代码,很简单的一段代码,只是模拟问题所在,

  

   设置完了之后,激活,创建DTP,加载数据到DSO,一片可爱的绿色…….

  

   查看New Data,也没错,/BIC/IK_RQty确实也是我在End Routine中要实现的值。

 

    但奇怪的事来了,激活此请求,查看Active Data:

    /BIC/IK_RQty变成了0…….难过

   

    上网搜了许多的资料,发现一位仁兄的文章,他也遇到这个问题,也说了解决办法:如查要用End Routine来更新数据,那么这个字段要设置为常量。我也按他的方法试试,在Rule Detail中,改为Constant,点击下面的按钮“Transfer Value”,然后激活转换规则。

   

    再加载数据到DSO,看看。

   加载后,查看New Data表,没错。  

    激活DSO,再来看看Active Data表,这时候就对了嘛。  

    很感谢很多热心的人将自己宝贵的经验放在网络上分享,使许多的人豁然开朗,受益菲浅吐舌头

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值