OAF_EO系列5 - Update详解和实现(案例)

简介: 2014-06-14 Created By BaoXinjian 一、摘要 Initialize data(数据初始化): 用于新增记录对值Value的初始化 1.在Design time 时设定Page item的Default value.

2014-06-14 Created By BaoXinjian

一、摘要


Initialize data(数据初始化):

用于新增记录对值Value的初始化

  • 1.在Design time 时设定Page item的Default value.
  • 2. 在Run time 时用编程方式设定, Default value的设定这里不说.留待后面”深入UI item”时再说.

用于在新增记录时,值的联动设定

  • 1. 在页面时的联动,如果用户选择某个值,自动带出另外的控件的默认值,如两个list的联动,选择省份后自动带出城市
  • 2. 在页面Commit时,根据用户输入的值,进行逻辑判断后,多某些其他相关栏位进行复制,这些栏位的默认值无法在一开始导入页面就决定,必须根据用户的输入的某些信息

用于新增记录对值WebBean控件属性的初始化

 

二、普通默认值设定


这里主要说说如何利用编程方式设定.

在建好EO后,如果你选择了生成JAVA文件及JAVA CLASS,我们在该EO下会发现有个<Your EO name>EOImpl.java 的节点,

双击打开后,里面已经有了一些方法了,主要有如下几类:

  1. DML Operation Class
  2. Set Attribute Value Class
  3. Get Attribute Value Class
  4. Validation Class

1. 那我们要初始化,很明显是要用到其中的Set Attribute Value Class. 这些方法名字都是 set +<Attribute Name>. 例如:  

public void setHeaderId(Number value) {

    setAttributeInternal(HEADERID, value);

}

传入参数是value, 然后利用setAttributeInternal 方法把value 赋给HEADERID(注意,

这个HEADERID是 EO Attributes 的别名. 在EO中为Attribute赋值主要有如下两个方法:

setAttribute(int index, String lang , object  val)

index代表Attribute在EO中的位置(注意,只在显示在Page上的Attribute中排序),也可用EO Attributes 的别名代替.

val 代表传入的值,lang 代表语言,可省略。例如:

Number price =  new Number(100);

setAttribute(5, price);

按照FORM的习惯,我们可能会写成   setAttribute(5,100), 

请注意,这是错误的,因为JAVA会认为这个100 是基本类型中int 类型,而不是object 类型。

2. 我们可以自已写个CLASS,把所有需要初始化的Attributes全部在里面设定好.如下:

public void  setallAttribute(){

Number v_id = new Number(100);    

setLineId(v_id);

String v_desc = new String(“ABCD”);

setItemDesc(v_desc);

}

3. 然后在其中的一个DML Operation class: create()中加入上述方法:

public void create(AttributeList attributeList){

super.create(attributeList);

setallAttribute();

}

这样,当你在Page上执行新增记录的动作时,你会发现有些字段就有了初始值了…

 

三、特殊的默认值设定


在初始值的定义中,有下面几个比较特殊的:

  • Primary Key的初始化
  • WHO字段的初始化
  • 需要动态指定字段的初始化

1. Primary Key 的初始化

调用OADBTransaction来取得Sequence值,并通过SetAttribute( ) 方法赋予Primary Key即可. 代码如下:

public void create(AttributeList attributeList){

    super.create(attributeList);

    OADBTransaction transaction = getOADBTransaction(); 

    Number lineid = transaction.getSequenceValue("xx_order_line_s");

    setLineId(lineid);

}

上面的代码是写在EO 的  create( )方法里的,这样的话,当你新增一个空记录时,在lineid字段上就有了一个初始值,即序列

取得的值,如果你不保存这条记录的话,就会出现跳号的情况,因此可把这个语句放在提交的方法里.

 

2. WHO字段的初始化

正常情况下,如果你的EO中包含了WHO字段的话,当你提交时,OAF会自动帮你初始化WHO字段,是不需要编写代码的,

如果你需要自已来获取WHO 信息的话, 仍可以利用OADBTransaction的方法来获取,主要有如下几个.

OADBTransaction transaction = getOADBTransaction(); 

transaction.getUserId()

transaction.getCurrentDBDate()

transaction.getResponsibilityApplicationId()

transaction.getResponsibilityId()

 

 3. 需动态赋值字段的初始化

这种情况我们在做FORM时经常遇到,即根据某一种情况需实时从数据库中提取某一信息做为字段的值.

如果提取不出来,还要报出错误信息来并拒绝保存记录. 那么在OAF中如何实现呢?

我想了一下,可能的实现手段包括:

1. 利用VO 来实现(有时候,VO就相当于FORM中的Recordgroup),需动态的为VO定义WHERE条件,并获取VO的查询结果来实现.

2.  利用JDBC或SQLJ来实现,这两种模式均支持在JAVA中直接使用标准SQL语句.

 

4. 利用JDBC和Database交互获取默认值

但那仅限于DML语句,象Update, Delete, Insert等等.这里我们需要执行一个SQL查询,并有结果集返回.

然后把结果集中的某个字段赋给EO的某个Attribute. 我想,这个在以后OAF开发中是非常有用的.

经研究, 成功实现,伪码如下:

--------------------------------------------------------------------

public void create(AttributeList attributeList)

{

    super.create(attributeList);

try

   OracleConnection conn =  (OracleConnection)transaction.getJdbcConnection(); //获取当前连接

   OracleStatement stmt = (OracleStatement)conn.createStatement();  //生成语句

   OracleResultSet rset = (OracleResultSet)stmt.executeQuery("select msi.segment1  from mtl_system_items_b msi"); //执行查询

   while (rset.next()) //向前转移指针

   {

    setItemDesc(rset.getString(1)); //获取结果集中的第一个字段

    break;  //假定只取一条记录

   }

   rset.close(); //关闭结果集

} catch(SQLException ex) {}

   //process exception

}

------------------------------------------------------------------------

注意, JDBC的方法往往要抛出异常,为java.sql.SQLException. 如果不进行捕获,OAF会报错.

 

四、案例 - 页面打开时对页面某些栏位进行初始化设置


1. 打开页面时,页面调用CO中的processRequest进行初始化

2. CO调用AM中的方法,新增VO Row

3. VO在新增Row时,系统会自动调用EO中的方法,在EO SetAttribute中进行所有值得初始化

4. 最后页面呈现的两个默认值被初始化

 

五、案例 - 页面保存时对页面某些栏位进行值判断并复制


1. 打开页面输入值后保存

2. 系统保存时,调用CO,后调用AM,AM中进行Commit时,系统会自动调用EO中的ValidateEntity,可以在这里进行值得组合

3. 查看数据库,查看comments通过页面值组合后得出

 

Thanks and Regards

参考: Tony Liu 深入EO系列

ERP技术讨论群: 288307890
技术交流,技术讨论,欢迎加入
Technology Blog Created By Oracle ERP - 鲍新建
相关文章
|
2月前
|
SQL 关系型数据库 MySQL
ThinkPHP6 连接使用数据库,增删改查,find,select,save,insert,insertAll,insertGetId,delete,update方法的用法
本文介绍了在ThinkPHP6框架中如何连接和使用数据库进行增删改查操作。内容包括配置数据库连接信息、使用Db类进行原生MySQL查询、find方法查询单个数据、select方法查询数据集、save方法添加数据、insertAll方法批量添加数据、insertGetId方法添加数据并返回自增主键、delete方法删除数据和update方法更新数据。此外,还说明了如何通过数据库配置文件进行数据库连接信息的配置,并强调了在使用Db类时需要先将其引入。
ThinkPHP6 连接使用数据库,增删改查,find,select,save,insert,insertAll,insertGetId,delete,update方法的用法
MybatisPlus-标准CRUD制作,新增boolean save(T t),删除 ~ delete(int id),修改 ~ update(T t),根据id查询,T getById....
MybatisPlus-标准CRUD制作,新增boolean save(T t),删除 ~ delete(int id),修改 ~ update(T t),根据id查询,T getById....
|
5月前
|
SQL 数据库
`UPDATE FROM` 的语法以及常见的更新操作方式
`UPDATE FROM` 的语法以及常见的更新操作方式
863 2
|
6月前
|
SQL 存储 关系型数据库
MySQL技能完整学习列表8、触发器、视图和事务——1、触发器(Triggers)的使用——2、视图(Views)的创建和使用——3、事务(Transactions)的管理
MySQL技能完整学习列表8、触发器、视图和事务——1、触发器(Triggers)的使用——2、视图(Views)的创建和使用——3、事务(Transactions)的管理
83 0
|
SQL 索引
【笔记】开发指南—DAL语句—CHECK GLOBAL INDEX
您可以使用CHECK GLOBAL INDEX语句检查主表和索引表的数据是否完全一致,并修订不一致的数据。
|
数据库
几种多数据库表update的方式测试
几种多数据库表update的方式测试
123 0
|
测试技术
OAF_开发系列24_实现OAF更新记录显示Record History(案例)
20150716 Created By BaoXinjian 一、摘要 OAF页面控件中显示记录历史信息有如下的限制: 1. 首先当然是后台的表结构中必须包含WHO字段列了 2. 基于的视图对象必须是非PL/SQL的可更新VO 3.
1062 0
|
关系型数据库 测试技术
OAF_开发系列13_实现OAF通过Vector动态查询设置(案例)
20150715 Created By BaoXinjian 一、摘要 Oracle OAF Guide上介绍的标准客制化查询的方式,在多条件下进行查询 具体实现步骤如下 Step1.在controler中的processRequest 的方法中调用 (1).
1634 0
OAF_开发系列06_实现OAF属性集的介绍和开发Attribute Set(案例)
20150705 Created By BaoXinjian 一、摘要 EBS OAF开发中属性集(Attribute Set)的介绍和手工实现。 在OAF开发中就和Form开发中一样,有时也要给一些对象设置统一的特定属性。
1425 0