Java 如何在Adf中撤消编辑后保留当前行的值?

Java 如何在Adf中撤消编辑后保留当前行的值?,java,oracle-adf,Java,Oracle Adf,我有一个弹出表单,可以在adf表中插入数据, 我可以按“添加”按钮插入行, 我可以编辑插入的行。 这是代码: 添加按钮: JSFUtils.setExpressionValue("#{pageFlowScope.status}", "add"); RichPopup.PopupHints hints = new RichPopup.PopupHints(); ResetUtils.reset(getmyPopup()); getmyPopup().show(hints); Operat

我有一个弹出表单,可以在adf表中插入数据, 我可以按“添加”按钮插入行, 我可以编辑插入的行。 这是代码: 添加按钮:

 JSFUtils.setExpressionValue("#{pageFlowScope.status}", "add");
 RichPopup.PopupHints hints = new RichPopup.PopupHints();
 ResetUtils.reset(getmyPopup());
 getmyPopup().show(hints);
 OperationBinding createOp = ADFUtils.findOperation("CreateInsert");
 createOp.execute();
“添加”弹出窗口有两个按钮“确定”和“取消”:

“确定”按钮:

  getmyPopup().hide();
问题是,当我在编辑模式下打开弹出窗口,更改LOV值,然后按下取消按钮时,弹出窗口中有一些LOV清除了一些输入文本 我试图恢复旧的行:并且 这是编辑按钮的代码:

  rowimpl currentRow = (rowimpl )ADFUtils.findIterator("iterator").getCurrentRow();
  rowimpl  backupRow=(rowimpl )ADFUtils.findIterator("iterator").getCurrentRow();
JSFUtils.setExpressionValue("#{pageFlowScope.value1}",currentRow.getValue1();
.
.
. // for all values 
这是取消按钮代码:

 DCIteratorBinding dciter = ADFUtils.findIterator("itertaor");
 dciter.getRowSetIterator().setCurrentRow(backupRow);

问题是备份行未正确设置为旧值

听起来您希望在用户取消编辑操作时执行部分回滚。为此,您可以为特定的VO编写一些方法,将它们公开为客户机接口,并将它们绑定到Cancel按钮。我记得最简单的方法是:

在VO中创建与EO链接的瞬态属性,该属性将指示当前行状态。将其设为整数,并将其命名为RowStatus或任何您喜欢的名称

在VO的ViewObjectRowImpl类中,找到上面创建的瞬态属性的getter方法,并将其替换为:

public Integer getRowStatus() {
    /*
     2-Modified
     0-New
     1-Unmodified
    -1-Initialized
    */
    byte entityState = this.getEntity(0).getEntityState();
    return new Integer(entityState);
}
ViewObjectImpl中创建一个方法,该方法将还原一行:

public void revertChangesCurrentRow(Row row) {
        if (row!= null) {
            row.refresh(Row.REFRESH_UNDO_CHANGES | Row.REFRESH_WITH_DB_FORGET_CHANGES);
        }
    }
ViewObjectImpl中创建另一个方法,该方法将根据每一行状态(从transient属性获得)删除新行或撤消更改,从而仅回滚此VO:

最后,在VO的客户端界面中公开方法revertOrRemoveRowValues,然后将其作为按钮拖放到页面上。这将把您上面写的函数绑定到按钮上,每次单击它时,它都会执行部分回滚,只在该VO上执行回滚。它通过删除已添加的新行或撤消对现有行的编辑来实现这一点,并且它还将使用DB中的值刷新VO(由于使用了this.executeQuery()命令,因此用户应该看到任何编辑之前的VO)

public void revertOrRemoveRowValues() {
ViewObject myVo = this;
RowSetIterator myVoIterator = myVo.createRowSetIterator(null);
        while (myVoIterator.hasNext()) {
         Row nextRow = myVoIterator.next();
            if (nextRow.getAttribute("RowStatus") != null) {
                Integer rowStatus = (Integer) nextRow.getAttribute("RowStatus");
                if (rowStatus == 2) {
                    //modified rows
                    revertChangesCurrentRow(nextRow);
                } else if (rowStatus == 0) {
                    //new row (added by create)
                    nextRow.remove();
                }
            }
        }
        this.executeQuery();
    }