2014-06-02 Created By BaoXinjian


实现OAF的新增功能insert的具体解析

建立EO时,在向导中选择生产Create Method,则EOImpl中会包含标准create()

public void create(AttributeList attributelist)

{

super.create(attributeList);

}

在以上方法中可以加入初始化方法,在super.create后

当用户进行create record时,数据流向如下

Page Create Page Button->CO 中processFormRequest -> AM具体的create方法 ->VO具体的create的方法 ->EO 中的create方法

在Create时必须的VO进行初始化,新增Row以存放需create record的内容

1. 创建记录常用的两种方式

  • 在新增一个主界面上有个Create按钮,一旦触发该按钮,直接跳到一个明细页,用以新增记录
  • 在主Table上,有个Add New An Record按钮,一旦触发该按钮,直接在表后新增一个Record,用以新增记录

2. VO的数据的三个层次

  • View Object
  • Row
  • Attribute

3. EO Row的六个status

  • STATUS_NEW-> 新增记录状态
  • STATUS_DELETED-> 记录已被删除状态
  • STATUS_MODIFIED-> 记录已被修改状态
  • STATUS_UNMODIFED-> 记录未被修改或者已修改未提交
  • STATUS_DEAD-> 新增未提交即被删除
  • STATUS_INITALZIED -> 初始化状态

注意点:当执行EO的create()方法后,EO默认Row的状态为STATUS_NEW,这时,这条Row会被加入OAF的校验队列里,也就是说OAF会对这 条记录进行有效性的校验.这时,如果你的记录中有必填项,但新增时必然还没填入值,这校校验失败,OAF会返回错误信息,当然,新增动作也就失败了.因 此,我们可以加上row.setNewRowState(Row.STATUS_INITIALIZED)来设置记录状态为初始化状态,这样,这条记录将 不再进入校验队列,所以可以正常的建立,并输入值了

4. AM Create Date关键方法

public void createData()

{

OAViewObjectImpl vo1 = this.getOrderLineVO1(); //取得VO的实例

Row row = vo1.createRow();  //新增记录

vo1.insertRow(row); //插入记录

row.setNewRowState(Row.STATUS_INITIALIZED); //置EO Row的状态

}

5. AM Commit Date关键方法

public void applyDate()

{

getOADBTransaction().commit();

}


案例:从主页面ExpenseSummary.PG通过按钮Create,跳转至明细页面ExpenseCreate.PG,对Expense进行新增

1. 通过ExpenseSummary.PG主界面中的Create按钮进行跳转

2. 跳转至明细页面ExpenseCreate.PG

2.1 在导入页面过程中,触发CO的processRequest方法

2.2 在CO中调用AM中初始化方法

2.3 AM在初始化VO和Row时,系统会自动调用EOImpl中的方法

由他文进行介绍,在此略过

2.4 处理后系统跳转至ExpenseCreate明细页面

3. 输入数据后,点击保存save按钮,对数据进行处理进入database

3.1 输入数据

3.2 触发CO中processFormRequest方法

3.3 在CO中调用AM中方法,对Transaction进行Commit

4. Commit后数据进入数据库,进行查看


案例:再进一步,结合上面,在定义对Expense Line进行操作,通过Add an new line对表新增行

1. 在点击Add an new line后触发CO中的代码,在通过CO触发AM中的关键初始化代码

2.  有些步骤就略去,看下图,点击add an new line后,系统会自动增加一行expense line,实现了Expense Header和Line的主从关

3. 新增后查看数据

Thanks and Regards

OAF_EO系列4 - Create详解和实现(案例)的更多相关文章

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

    2014-06-14 Created By BaoXinjian

  2. OAF_EO系列3 - Initialize详解和实现(案例)

    2014-06-14 Created By BaoXinjian

  3. OAF_EO系列6 - Delete详解和实现(案例)

    2014-06-14 Created By BaoXinjian

  4. nginx高性能WEB服务器系列之四配置文件详解

    nginx系列友情链接:nginx高性能WEB服务器系列之一简介及安装https://www.cnblogs.com/maxtgood/p/9597596.htmlnginx高性能WEB服务器系列之二 ...

  5. mongo 3.4分片集群系列之六:详解配置数据库

    这个系列大致想跟大家分享以下篇章: 1.mongo 3.4分片集群系列之一:浅谈分片集群 2.mongo 3.4分片集群系列之二:搭建分片集群--哈希分片 3.mongo 3.4分片集群系列之三:搭建 ...

  6. mongo 3.4分片集群系列之五:详解平衡器

    这个系列大致想跟大家分享以下篇章: 1.mongo 3.4分片集群系列之一:浅谈分片集群 2.mongo 3.4分片集群系列之二:搭建分片集群--哈希分片 3.mongo 3.4分片集群系列之三:搭建 ...

  7. Hexo系列(二) 配置文件详解

    Hexo 是一款优秀的博客框架,在使用 Hexo 搭建一个属于自己的博客网站后,我们还需要对其进行配置,使得 Hexo 更能满足自己的需求 这里所说的配置文件,是位于站点根目录下的 _config.y ...

  8. css3系列之transform详解translate

    translate translate这个参数的,是transform 身上的,那么它有什么用呢? 其实他的作用很简单,就是平移,参考自己的位置来平移 translate() translateX() ...

  9. ThreeJS系列1_CinematicCameraJS插件详解

    ThreeJS系列1_CinematicCameraJS插件详解 接着上篇 ThreeJS系列1_CinematicCameraJS插件介绍 看属性的来龙去脉 看方法作用 通过调整属性查看效果 总结 ...

随机推荐

  1. MySQL复制的基本概念和实现

    MySQL的复制的概念是完成水平扩展的架构 MySQL性能方面的扩展方式有scale on(向上扩展,垂直扩展)                          scale out(向外扩展,水平扩 ...

  2. JS原型链原理(链表)

      任何一个对象都有一个prototype的属性,在js中可以把它记为:__proto__   当初ECMAscript的发明者为了简化这门语言,同时又保持继承的属性,于是就设计了这个链表..在数据结 ...

  3. 用360安全浏览器控制网速,调试loading

    360安全浏览器 按f12 两个按钮的意思分别为禁止缓存,网络设置,这样就能控制网速了,调试loading了

  4. ChannelOption.TCP_NODELAY, true->浅谈tcp_nodelay的作用

    在TCP/IP协议中,无论发送多少数据,总是要在数据前面加上协议头,同时,对方接收到数据,也需要发送ACK表示确认.为了尽可能的利用网络带宽,TCP总是希望尽可能的发送足够大的数据.这里就涉及到一个名 ...

  5. How to calculate a good InnoDB log file size

    Peter wrote a post a while ago about choosing a good InnoDB log file size.  Not to pick on Peter, b ...

  6. Mydumper & Myloader Documentation

    Mydumper.org web site has been missing in action for a while now. I've uploaded a copy of the Mydump ...

  7. IIS_PUT

    [*] Put file success http://58.16.95.114:80/1470546504.01.txt [*] Put file success http://58.17.121. ...

  8. SQL Server系统数据库

    Master Master数据库保存有放在SQLSERVER实体上的所有数据库,它还是将引擎固定起来的粘合剂.由于如果不使用主数据库,SQLSERVER就不能启动,所以你必须要小心地管理好这个数据库. ...

  9. SDWebImage使用详解

    这个类库提供一个UIImageView类别以支持加载来自网络的远程图片.具有缓存管理.异步下载.同一个URL下载次数控制和优化等特征.使用示范的代码:UITableView使用UIImageView+ ...

  10. android dimens 读取 px&dp问题

    1.dimens.xml文件:     <resources> <dimen name="area_margin_top">100dp</dimen& ...