2020-08-18 16:37发布
加入QQ群:457200227(SAP S4 HANA技术交流) 群内免费提供SAP练习系统(在群公告中)
嗨,
我对DI API文档中某些行对象上可用的功能SetCurrentLine()感到有些困惑。 是使用LineNum值还是VisOrder值?
经过研究,我发现VisOrder或LineNum都不适合SetCurrentLine()方法。
最好的选择是遍历行并找到所需的行:
for(int j = 0; j 在我的情况下,我试图从交货单中获取基线,所以我必须匹配BaseLine和LineNum。
在我的情况下,我试图从交货单中获取基线,所以我必须匹配BaseLine和LineNum。
是的,您是对的。 两者都不适合。 这是后来发现的。 抱歉,忘记更新此问题。
它使用的是LineNum值。
此visorder仅在前端使用。
Regarts
Ad
您好Sinoj,
经验法则,SetCurrentLine(VisOrder)
对于 系统对象VisOrder由内部SAP控制,并且基于零。
使用VisOrder传入是安全的。
如果不是系统对象(例如UDO),则此 VisOrder有时不是基于零的。
在这种情况下,您需要查询记录并创建自己的基于零的索引,并按VisOrder进行排序。
即
选择CONVERT(INT,Row_Number()Over(ORDER BY VisOrder))ID,* FROM RDR1 WHERE DocEntry = 1
并将ID值传递到SetCurrentLine中。
注意 Edy
最多设置5个标签!
经过研究,我发现VisOrder或LineNum都不适合SetCurrentLine()方法。
最好的选择是遍历行并找到所需的行:
是的,您是对的。 两者都不适合。 这是后来发现的。 抱歉,忘记更新此问题。
嗨,
它使用的是LineNum值。
此visorder仅在前端使用。
Regarts
Ad
您好Sinoj,
经验法则,SetCurrentLine(VisOrder)
对于 系统对象VisOrder由内部SAP控制,并且基于零。
使用VisOrder传入是安全的。
如果不是系统对象(例如UDO),则此 VisOrder有时不是基于零的。
在这种情况下,您需要查询记录并创建自己的基于零的索引,并按VisOrder进行排序。
即
选择CONVERT(INT,Row_Number()Over(ORDER BY VisOrder))ID,* FROM RDR1 WHERE DocEntry = 1
并将ID值传递到SetCurrentLine中。
注意
Edy
一周热门 更多>