EBS OAF开发中实体对象和视图对象的属性设置器
(版权声明。本人原创或者翻译的文章如需转载,如转载用于个人学习,请注明出处;否则请与本人联系,违者必究)
源文:
Home > Oracle Application Framework Documentation Set, Release 12.2 > Oracle Application Framework Developer's Guide > Chapter 5: Implementing Server-Side Features > Entity Object and View Object Attribute Setters
概览
在oracle.apps.fnd.framework.server.OAEntityImpl和oracle.apps.fnd.framework.server.OAViewRowImpl类中有非常多方法使你在编程的时候为实体对象和视图对象设置属性值。这篇文档解释了每一个可行的选项并在不同的情景下建议合适的使用。
注意:这里不解释怎样声明式设置实体对象和视图对象的属性值。能够參考Defaulting in Implementing the View
内容
这篇文档依据属性缓存的地方组织为两个基本的部分:
l 缓存在视图对象上属性值
l 缓存在实体对象上的属性值
阅读前提.
l Java实体对象
l 视图对象的具体介绍-视图对象的属性类型和缓存(了解不同的视图对象属性类型)
缓存在视图对象上的属性值
方法概观
对于存储在视图对象层的属性(它们不映射到实体对象属性),你能够使用以下OAViewRowImpl中方法来设置属性值。
方法1:基本设置器-setAttribute()
1. setAttribute(String name, Object val)
2. setAttribute(int index, Object val)
这两个方法会运行你为它们定义的全部编程验证,然后在super.setAttribute()中,它们使用查找机制来查找并调用相关的set<AttributeName>()方法(注意。你必须在你的代码之后调用super.setAttribute())。
3. set<AttributeName>() //Attribute setter in OAViewRowImpl subclass
这种方法会运行你为这种方法定义的全部编程验证,然后调用方法setAttributeInternal()。注意,你必须在你的代码之后调用setAttributeInternal()方法。
这三个方法会标记依赖的视图对象的查询集合为”脏”状态(你调用它们之后,方法OAViewObjectImpl.isDirty()会返回true).关于isDirty()检查的很多其它信息请參考Advanced View Object DevelopmentTopics -> Entity Event Notification。
方法2:setAttributeInternal( )
1. setAttributeInternal(int index, Object val)
这种方法会运行全部在视图对象XML文件里为视图对象属性指定的全部声明式验证。
和
setAttribute()方法一样。这种方法也会把依赖的视图对象的查询集合标记为”脏”状态。
由于这种方法仅仅运行声明式验证,你不应该覆盖它(你不须要这么做,由于它不应该包括编程式验证);你应该依据须要简单的调用它。
方法3:"Populate" Methods
1. populateAttribute(int index, Objectvalue)
2. populateAttributeAsChanged(int index, Object value)
这些方法会为属性设置值,可是不会运行不论什么验证也不会影响视图对象查询集合的”脏”标记。
你不要覆盖这种方法并往populate* 方法增加编程验证代码,由于这些方法就是用于简单为属性设置值。
注意:对于实体对象层属性。populateAttributeAsChanged(intindex, Object value)方法的行为不同;參考以下的“缓存在实体对象上的属性值”部分。
以下是一个自己定义视图行的演示样例演示了怎样使用这种方法设置表的选择器的值而不影响视图对象的状态。
public void setSelectFlag(String value) { //Do not call setAttributeInternal as usual in this method. // setAttributeInternal(SELECTFLAG, value); populateAttribute(SELECTFLAG, value); }
行为汇总
l set*方法会运行验证并标记视图对象的查询集合”脏”状态。populate*方法简单设置值而不进行不论什么验证也不改变视图对象的状态。
使用便条
使用基本设置(选项1)应该作为使用规则,除非你有以下的特殊情形:
l 假设你须要忽略编程验证并仅调用声明式验证,那么你须要使用来setAttributeInternal(intindex, Object val)取代。
l 设置一个属性值而不触发验证或者不影响视图对象的查询集合的”脏”状态。要使用populateAttribute(intindex, Object value)方法.比方,像上面演示的。你可能覆盖一个table bean的”选择器”属性的设置器方法来使用populateAttribute()方法。这同意你存储特定的UI状态而不改变VO的状态。
关于“selector”的很多其它信息,可參考Tables - Classic and Tables - Advanced
注意:一定不要使用populate*方法来设置主键属性值(这对组合关系可能有不利后果)。应为主键属性使用主要的设置器。
缓存在实体对象上的属性值
对于存储在实体对象层的属性(它们不映射到实体对象属性),你能够使用以下OAEntityImpl中方法来设置属性值。
注意:在大多数情况下,你通常调用类OAViewObjectImpl 和OAViewRowImpl上上面描写叙述的方法来设置实体对象的值(VO方法终于代理潜在的实体对象方法)。当在你的OAEntityImpl子类中写代码时,可是。你能够调用以下的方法来直接设置实体属性值。
当你调用一个实体对象的比方set<AttributeName>()方法时,你的调用会影响以下的实体对象状态:
l 验证状态(Validationstate)-可通过调用来OAEntityImpl.isValid()检查
l 提交状态(Poststate)- 可通过调用来OAEntityImpl. getPostState ()检查
l 事务状态(Transactionstate)可通过调用来OAEntityImpl. getEntityState ()检查
由于BC4J为实体对象维护这些额外的状态(此外,为视图对象维护的基础的”脏”状态), OAEntityImpl方法细粒度控制怎样设置属性值。
方法概观
方法1:基本设置器-setAttribute()
1. setAttribute(String name, Object val)
2. setAttribute(int index, Object val
这两个方法会运行你为它们定义的全部编程验证,然后在super.setAttribute()中。它们使用查找机制来查找并调用相关的set<AttributeName>()方法(注意。你必须在你的代码之后调用super.setAttribute())。
3. set<AttributeName>() //Attribute setter in OAEntityImpl subclass
这种方法会运行你为这种方法定义的全部编程验证,然后调用方法setAttributeInternal()。
注意,你必须在你的代码之后调用setAttributeInternal()方法。
这三个方法会标记实体对象为无效状态并依据须要更改实体对象的提交状态和事务状态为STATUS_NEW或者STATUS_MODIFIED。以便BC4J知道实体对象有未提交的改动。
最后,这三个方法也会标记依赖的视图对象的查询集合为”脏”状态。(你调用它们之后,方法OAViewObjectImpl.isDirty()会返回true)
方法2:setAttributeInternal( )
1. setAttributeInternal(int index, Object val)
这种方法会运行全部在视图对象XML文件里为实体对象属性指定的全部声明式验证。和
setAttribute()方法一样。这种方法也会把依赖的实体对象标记为无效状态。改变提交状态和事务状态。也标记依赖的视图对象的查询集合为”脏”状态。
由于这种方法是用来只运行声明式验证。你不应该覆盖它(你不须要这么做,由于它不应该包括编程式验证);你应该依据须要简单的调用它。
方法3:"Populate" Methods
在看每一个单独的方法之前。来看一下在大多数populate*方法中能够使用的參数的描写叙述。
Method Parameter | Description |
sendNotification | 控制是否把实体属性值的改变事件广播给依赖的视图对象。改变事件会运行视图对象查询集合的状态(“脏”标记) .很多其它信息可參考 Advanced View Object Development Topics -> Entity Event Notification |
markAsChanged | 当这个參数设置为true时,这个属性被标记为已改变.
|
saveOriginal | 控制BC4J是否在更改值之前保存原先从数据库中取到的值到额外的地方. 假设你想保存原先的值:
假设原先的值没有保存,那么当前的属性值会被BC4J用来做这些操作. |
1. populateAttribute(int index, Objectvalue)
这种方法的行为和以下的调用是一样的:
populateAttribute(index, value,
false, // sendNotification
false, // markAsChanged
false);// saveOriginal
2. populateAttributeAsChanged(int index,Object value)
这种方法的行为和以下的调用是一样的:
populateAttribute(index, value,
false, // sendNotification
true, // markAsChanged
false);// saveOriginal
3. populateAttribute(int index, Objectvalue,
booleansendNotification,
BooleanmarkAsChanged)
这种方法已经不建议使用了.它调用了populateAttribute(index, value, sendNotification,markAsChanged, false).
4. populateAttribute(int index, Object value,
BooleansendNotification,
BooleanmarkAsChanged,
BooleansaveOriginal)
l 你不应该覆盖这些方法并加入编程验证逻辑,由于这些方法都是用来简单设置属性值的。
l 这些方法不会影响实体对象的验证状态。提交状态或者事务状态。
l 视图对象的查询集合的”脏”标记可通过sendNotification标记值来影响。
建议的參数值
l 对于OAF应用,设置sendNotification为false因此视图对象的查询集合的脏标记不会被你的改动而影响。当视图对象的查询集合变脏。表中相似排序操作都是不同意的(很多其它信息可參考Tables - Classic and Tables - Advanced)。
l 设置markAsChanged为true,假设你想提交属性值和其它用户改动在DML期间提交到数据库的话。
l 假设你设置markAsChanged为true的话。就设置saveOriginal为true.作为规则,帮助合适的加锁和处理提交失败。假设你计划提交改动的属性值到数据库。saveOriginal參数应该设置为true.
行为汇总
l set*方法会运行验证并标记实体对象为无效状态,改变实体对象的提交状态,改变实体对象的事务状态。并标记视图对象的查询集合为脏状态。
l populate*方法简单设置值而不进行不论什么验证也不改变实体对象的状态。可是,视图对象的查询集合状态(包括脏标记)受sendNotification參数值的影响。
使用便条
使用基本设置(选项1)应该作为使用规则,除非你有以下的特殊情形:
l 假设你须要忽略编程验证并仅调用声明式验证。那么你须要使用来setAttributeInternal(intindex, Object val)取代。
l 为实体对象使用populate*方法是不鼓舞的。尽管那么说。可是,也有一些例外的情况你须要使用这些方法;以下描写叙述了这些用例,并针对属性类型有不同的建议(假设不熟悉这些类型的名称。可參考ViewObjects in Detail - View Object Attribute Types and Caching)。
注意:对于Java实体对象。一定不要使用populate*方法来设置主键属性值(这对组合关系可能有不利后果)。应为主键属性使用主要的设置器。
对于“刷新插入”行为的PL/SQL实体对象,很多其它信息,可參考PL/SQLEntity Objects - Creating Primary Keys。
对于全部实体起源的属性类型。不要使用populateAttributeAsChanged(intindex, Object value)方法,除非你真的不关心在提交失败之后能不能又一次提交(由于populateAttributeAsChanged()方法的saveOriginal= false)。
实体起源的持久属性
对于视图起源的持久属性,在大多数情况下。你不须要调用populate*方法。
为一个新行设置这些属性的默认值。更好的方法是使用主要的设置器方法然后调用OAViewRowImpl.setNewRowState(Row.STATUS_INITIALIZED)方法来把这行作为”暂时”的直到用户对其做了改动。很多其它信息可參考View Object State Management CodingStandard M69。
例外:
1. 要实现“刷新插入”行为的PL/SQL实体对象,你须要调用populateAttribute(index,value, false, false, false)方法。在DML操作之后commit之前。这是必须来马上同步属性值和数据库的值。像上面提到的一样,很多其它信息。请參考PL/SQLEntity Objects - Creating Primary Keys。
2. 假设你想为实体起源的属性值设置这样它能够和其它用户改动的值一起提交而不触发验证或者不影响实体对象的验证。提交或者事务状态,或者实体对象查询集合的脏标记。比方,OAF框架用这样的方式设置标准的WHO字段和ObjectVersionNumber属性值。
实体起源的非持久属性
对于实体起源的非持久属性,通常来说。你应该在实体对象属性的getter(get<AttributeName>())方法计算并返回值而不是设置值。
l 假设由于一些原因,你不能使用这种方法,你仍旧能够使用主要的设置器方法-可是请注意这些调用会更改实体对象的验证,提交和事务状态和视图对象查询集合的脏标记。
也要明确你不应该存储不论什么UI状态到一个实体起源的非持久属性上。
注意:当视图对象行集合在提交后被刷新时。实体起源的非持久属性值会丢失。假设你想保留这些值,请參考Persisting Entity-Derived TransientAttribute Values After Commit 。
l 而不用主要的设置器方法,你能够使用populateAttribute(index,value, false, true, true)(设置markAsChanged属性值为true)来避免触发验证或者影响实体对象验证。提交或者事务状态,或者视图对象查询集合的脏标记。
注意:非持久属性值不映射到不论什么数据库的表列,因此,不会被提交。
也要明确你不应该存储不论什么UI状态到一个实体起源的非持久属性上。
l 避免使用參数markAsChanged为false的populateAttribute(intindex, Object value) 或者 populateAttribute()方法。