mybatis :Criteria 查询、条件过滤用法

前些天发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默,忍不住分享一下给大家。点击跳转到教程。

PS:hibernate 中也有 Criteria 的用法,见另一文章:jpa : criteria 作排除过滤、查询

1. 包:

import tk.mybatis.mapper.entity.Example;
import tk.mybatis.mapper.entity.Example.Criteria;

2. 使用:

    public void getQueryExampleByCondition(Example example, OrderQuery query) {

        Criteria criteria1 = example.createCriteria();

        // 设置 criteria2 与 criteria1 为 or 方式关联
        Criteria criteria2 = example.or(); 
       
        if (query != null) {
            
            if (query.getLoadSrc() != null && query.getLoadSrc() != -1) {
                criteria1.andEqualTo("loadSrc", query.getLoadSrc());
            }
                    
            if (!StringUtil.isEmpty(query.getOrderNo())) {
                criteria1.andLike("orderNo", "%" + query.getOrderNo() + "%");
            }

            // 以下 3 个会用 OR 方式加上 criteria2 中的条件
            if (query.getStatus() != null && query.getStatus() != -1) {
                criteria1.andEqualTo("status", query.getStatus());
                criteria2.andEqualTo("status", query.getStatus());
            }

            if (!StringUtil.isEmpty(query.getRepayDateEnd())) {
                criteria1.andLessThanOrEqualTo("repayDate", query.getRepayDateEnd());
                criteria2.andLessThanOrEqualTo("repayDate", query.getRepayDateEnd());
            }

            if (!StringUtil.isEmpty(query.getLoanDay())) {
                criteria1.andEqualTo("loanDay", query.getLoanDay());
                criteria1.andEqualTo("loanDay", query.getLoanDay());
            }

        }
    }

其中 criteria1 和 criteria2  是 or 的关系。

根据传入参数不同,执行 sql 效果类似:

SELECT * FROM xxxx WHERE (load_type = 5 AND loan_day = 7) OR (order_No = 5) 

where 后面第一个圆括号中的条件组合 load_type = 5 AND loan_day = 7 是 criteria1中的条件,

第二个圆括号中的条件 order_No = 5 是 criteria2 中的条件设置。

 

 

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值