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

187 篇文章 2 订阅
开发运行环境: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

http://maping930883.blogspot.com/2010/04/adf069adf-bc-getcriteriaitemclausecrite.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值