前段时间,因为需求量有点多,然后我有个需求是用户保存后需要将子分录的数据写到分录上,那么就要新增分录,新增分录把数据写上去确实简单,但是没关联关系,不能反写呀,我看了看拆分行的插件,很成功的没看明白,可能我有点菜吧......
我就另辟蹊径,我用个不给可见性的字段把要反写的数量放在这,相同物料的这个字段都是相同的数量,也能搞定,后来,测试的时候,有人提出,要是把有关联关系的分录行删掉了,岂不是没法反写了?我觉得很有道理,然后问了同事,找到了解决方案,那就是给新增分录添加关联关系!!
如下:
首先呢,创建一个分录行,
DynamicObject NewEntry = new DynamicObject(billentryFather.getDynamicObjectType());
DynamicObjectUtils.copy(billentryFather, NewEntry);
插入数据在新的分录后呢,就调用下面这个方法就OK了。是在不会,就copy下面这条代码
setEntryRelation(billentryFather, NewEntry); // 记录新增行关联关系
↓↓↓方法在这
private void setEntryRelation(DynamicObject purReceiveEntry, DynamicObject NewEntry) {
String entryKey = "billentry";
DynamicObjectCollection billentry_lk = purReceiveEntry.getDynamicObjectCollection("billentry_lk");
DynamicObjectCollection newEntryLk = NewEntry.getDynamicObjectCollection("billentry_lk");
Iterator var7 = billentry_lk.iterator();
while (var7.hasNext()) {
DynamicObject entryLk = (DynamicObject) var7.next();
DynamicObject newLk = new DynamicObject(entryLk.getDynamicObjectType());
newLk.set(entryKey + "_lk_stableid", entryLk.get(entryKey + "_lk_stableid"));
newLk.set(entryKey + "_lk_sbillid", entryLk.get(entryKey + "_lk_sbillid"));
newLk.set(entryKey + "_lk_sid", entryLk.get(entryKey + "_lk_sid"));
newEntryLk.add(newLk);
}
问题就圆满解决了,到此为止,整个帖子都被你看完了,希望对你有帮助,谢谢!