2010年4月13日星期二

ADF_069:使用ADF-BC 实现查询功能之九:重写getCriteriaItemClause方法设置Criteria中的变量

开发运行环境: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

没有评论: