2013年6月26日星期三

ADF_235:Groovy在ADF BC中的常见用法之三

开发运行环境:JDeveloper 11.1.2.4

前面介绍的都是在EO中使用Groovy,在VO中和在EO中使用Groovy的方法基本一样,同样支持
 (1)访问同一个VO中的Attribute
 (2)访问其它VO中的Attribute
 (3)定义Transient Attribute验证规则
 (4)调用ViewRowImpl中的自定义方法
 (5)使用集合功能
VO比EO更灵活的地方是,还支持
 (6)在Binding Variable中使用Groovy
在Binding Variable中的Groovy上下文默认是ViewObjectImpl,而不是单一的Row对象,所以无法访问每行的Attribute。
另外,Groovy可以调用对应的Java类中的自定义方法,在EO中是EntityImpl,在VO中是ViewRowImpl,而不是ViewImpl。
因为ViewImpl代表的是整个集合,而ViewRowImpl代表的是集合中每一行对象。

我以一个常见的一个需求为例来说明如何在Binding Variable中使用Groovy:
客户登录之后,显示员工详细信息,其中Manager一项使用LOV实现下拉列表,并且要求只显示和登录员工所在同一部门的其它员工。

1. 为了不影响原有的Employees VO,新增一个Employees VO:EmployeesGroovyView

2. 增加一个Binding Variable:bvDepartmentId
其中的Value为adf.userSession.userData.DeptId,也就是说,从session中获取一个叫DeptId的值。

3. 增加一个ViewCriteria:EmployeesGroovyViewCriteria


4. 为ManagerId 增加一个LOV



使用一个指向自己的VO作为Accessors:


选中先前定义的EmployeesGroovyViewCriteria:


5. 还有一个问题没解决,如何设置session中的DeptId的值呢?
当然你可以在用户成功登录后,获取标准的Http Session对象,然后写代码设置。
这个例子只是了为了测试Groovy,所以我通过重写Application Module中的prepareSession方法来设置,并且设定DeptId=80。
 @Override
 protected void prepareSession(Session session) {
        session.getUserData().put("DeptId",new Number(80));
 }

prepareSession方法是用来做一些与特定用户session相关的一些初始化工作,比如调用一个存储过程初始化数据,或者设置一些应用级的配置参数。
该方法在创建新用户session时被调用,就是从AM Pool获取AM实例时被调用。

6. 运行效果


可以看出,ManagerId的下拉列表只显示DepartmentId=80的员工列表。


Project 下载:ADF_Groovy(3).7z

参考文献:
1. http://www.jobinesh.com/2011/03/initializing-bind-variables-in-query.html
2. http://www.jobinesh.com/2009/08/tips-on-lov-runtime.html
3. http://andrejusb.blogspot.jp/2012/01/how-to-access-session-scope-in-adf-bc.html
4. http://blog.csdn.net/qingqingxuelang/article/details/5784943
5. https://forums.oracle.com/thread/975097
6. http://adfcodebits.blogspot.jp/2010/06/bit-21-overriding-preparesession-to-do.html

没有评论: