CriteriaBuilder,实现Mysql 的 find_in_set 函数

实现方式:主要用到 CriteriaBuilder 接口中的function方法

1、单个参数实现

xxxRepository.findAll((root, query, cb) -> {
       //查询条件集合
       List<Predicate> predicateList = new ArrayList<>();
 
        //根据单个参数查询
        //param 为查询的参数  targetColName 为数据库中表的字段名
        if (StringUtils.isNotBlank(param)) {
            //返回参数在数据库中该字段的位置
            Expression<Integer> findInSetFun = cb.function("FIND_IN_SET", Integer.class,             
                                cb.literal(param), root.get("targetColName"));
            //设置条件 只要返回值 >0 则说明该参数存在于目标字符串中
            predicateList .add(cb.greaterThan(findInSetFun, 0));
        }
    }, pageable);

2、多个参数实现,原理同上,具体见下面截图

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值