开发运行环境:JDevloper 11.1.2.4.0+ Oracle Database 11gR2 XE
本文最后一次修改时间:2013-06-27
考虑这个场景:拖放ViewCriteria实现了查询功能,但是我希望对查询条件中的某个字段设置过滤条件,比如ManagerId以下拉列表的形式展现,并且只显示与当前登录用户同一部门的员工列表。
1. 为了不影响其它VO,这里新建一个VO:EmployeesOverrideView
2. 新建一个View Criteria:EmployeesOverrideViewCriteria,用做ManagerId的LOV的数据源,其中有一个参数:bvDepartmentId。
3. 在新建一个View Criteria:QueryEmployeesOverrideViewCriteria,用于生成查询界面。
4. 在EmployeesOverrideViewImpl.java重写方法:getCriteriaItemClause
@Override
public String getCriteriaItemClause(ViewCriteriaItem viewCriteriaItem) {
if ("EmployeesOverrideViewCriteria".equals(viewCriteriaItem.getViewCriteria().getName()) &&
"DepartmentId".equals(viewCriteriaItem.getName())) {
ensureVariableManager().setVariableValue("bvDepartmentId", new Number(80));
}
return super.getCriteriaItemClause(viewCriteriaItem);
}
这个例子只是功能验证测试,因此这里设置bvDepartmentId=80。
5. 运行
发现ManagerId的下拉列表只显示DepartmentId=80的员工。
Project 下载:ADF_Query_Criteria(3).7z
参考文献:
1. http://www.jobinesh.com/2009/08/tips-on-lov-runtime.html
没有评论:
发表评论