OAF_VO系列4 - Row Imp的分析(概念)

简介: 20150706 Created By BaoXinjian 一、摘要 如果使用过OAF(客户化或标准EBS页面)的人可能会发现这样两个问题:    1、当在表单上输入内容,点确定按钮出错后,页面显示错误信息,此时不做任何修改,再点确定按钮就不会再执行底层实体对象的验证。

20150706 Created By BaoXinjian

一、摘要


如果使用过OAF(客户化或标准EBS页面)的人可能会发现这样两个问题:

   1、当在表单上输入内容,点确定按钮出错后,页面显示错误信息,此时不做任何修改,再点确定按钮就不会再执行底层实体对象的验证。

   2、当你输入了内容,提交触发实体对象验证失败后,你所输入的数据可能无法保留,而显示原先的内容或者是默认的值。

第一个问题的原因是在于触发过实体对象验证,用户不修改任何值,不会引起实体对象的再次验证;

第二个问题的原因是在控制器的processFormData方法中,将页面中的值写入视图对象时,触发了实体对象的验证,造成无法把页面中的值写入视图对象属性,而保留原先的值或默认值。

 

二、方案


Step1. 在控制器中覆盖OAControllerImpl的processFormData方法,设置ROW的状态为STATUS_INITIALIZED

if ("Y".equals(pageContext.getTransactionValue("ErrorExist"))) //如果EO验证失败,设置该Transaction值
{
  RowSetIterator it = vo.createRowSetIterator("initIt");
  
  int rowCount = vo.getFetchedRowCount();
  it.setRangeStart(0);
  it.setRangeSize(rowCount);
  
  try
  {
     for (int i=0;i   
{    Row row
= it.getRowAtRangeIndex(i);    row.setNewRowState(Row.STATUS_INITIALIZED); // 将不执行实体对象的验证    }   }   finally   {    it.closeRowSetIterator();   }  }    super.processFormData(pageContext, webBean);

 

Step2. 然后在processFormRequest中强制执行Row的验证

if ((pageContext.getParameter("Submit") != null) && ("Y".equals(pageContext.getTransactionValue("ErrorExist"))))
{
   RowSetIterator it = vo.createRowSetIterator("checkIt");
  
   ArrayList exptList = new ArrayList();
  
   int rowCount = vo.getFetchedRowCount();
   it.setRangeStart(0);
   it.setRangeSize(rowCount);
  
   try
   {
      for (int i=0;i   {
      try
      {
        Row row = it.getRowAtRangeIndex(i);
  
      if (...) // 判断记录是否是新建的记录
      {
         row.setNewRowState(Row.STATUS_NEW); // 对于新建的记录,必须设置STATUS_NEW状态,才会触发实体验证
      }
      row.validate();
      }
      catch(Exception e)
      {
         exptList.add(e);
      }
     }
    }
    finally
  {
     it.closeRowSetIterator();
  }
  
  if (exptList.size() > 0)
  {
   OAException.raiseBundledOAExcetion(exptList);
  }
  
   pageContext.removeTransactionValue("ErrorExist");
}

 

Thanks and Regards

ERP技术讨论群: 288307890
技术交流,技术讨论,欢迎加入
Technology Blog Created By Oracle ERP - 鲍新建
相关文章
|
8月前
ABAP 数据字典里数据元素(Data Element),结构(Structure)和表类型(Table Type)三者的使用辨析试读版
ABAP 数据字典里数据元素(Data Element),结构(Structure)和表类型(Table Type)三者的使用辨析试读版
74 1
|
9月前
|
前端开发 Java API
深度解读JAVA中的DO、BO、VO、DTO、AO、PO、DO、AO各自的含义
在刚接触一些比较规范代码的时候就遇到了这些,用于描述对象的不同类型,每个模块都是相互依赖的,所以在这里进行一个详细系统的总结。
343 0
|
存储 关系型数据库 数据库
Data dictionary header(2) --系统表空间结构(三十四)
Data dictionary header(2) --系统表空间结构(三十四)
重构——29以数据类取代记录(Replace Record with Data Class)
以数据类取代记录(Replace Record with Data Class):你需要面对传统编程环境中的记录结构;为该记录创建一个“哑”数据对象
1518 0
SAP Spartacus Table cell显示数据类型的Component决定逻辑
SAP Spartacus Table cell显示数据类型的Component决定逻辑
98 0
SAP Spartacus Table cell显示数据类型的Component决定逻辑
SAP CRM Settype COM_TA_R3_ID的映射逻辑
SAP CRM Settype COM_TA_R3_ID的映射逻辑
90 0
SAP CRM Settype COM_TA_R3_ID的映射逻辑
如何使用BOL接口set_property修改SAP CRM BO实例的某个属性
如何使用BOL接口set_property修改SAP CRM BO实例的某个属性
124 0
|
SQL Oracle 关系型数据库
跟着吕大师(VAGE)揭密隐含参数:_db_writer_coalesce_area_size
[size=13.913043975830078px]最近在看吕大师的大作《Oracle核心揭密》,这部大作可以与Jonathan Lewis大师的《Oracle Core_ Essential Internals for DBA》相提并论,看了几天收益颇多,哈哈美国有Lewis,中国有VAGE。
跟着吕大师(VAGE)揭密隐含参数:_db_writer_coalesce_area_size