hibernate里面用in查询

hibernate中各种类型的查询条件拼接:

一、正常的传参查询(精确查询)

String shopAttendanceCode = queryHash.get("shopAttendanceCode");
        if (!StringUtils.isEmpty(shopAttendanceCode)) {
            conditionHash.put("shopAttendanceCode = ?{paramIndex} ", shopAttendanceCode);
        }

二、正常的传参查询(模糊查询)

String likeShopCode = queryHash.get("likeShopCode");
        if (!StringUtils.isEmpty(likeShopCode)) {
            conditionHash.put("shopCode like ?{paramIndex} ", "%" + likeShopCode + "%");
        }

三、日期类型的查询

String plainDate = queryHash.get("plainDate");
        if (!StringUtils.isEmpty(plainDate)) {
            conditionHash.put("plainDate = ?{paramIndex} ", StringConverters.ToDatePattern(plainDate,"yyyy-MM-dd"));//黄颜色部分返回Date类型
        }

四、日期范围查询

String startDate = queryHash.get("startDate");
        String endDate = queryHash.get("endDate");
        if (!StringUtils.isEmpty(startDate) && !StringUtils.isEmpty(endDate)) {
            conditionHash.put("plainDate >= ?{paramIndex} ", StringConverters.ToDatePattern(startDate,"yyyy-MM-dd"));
            conditionHash.put("plainDate <= ?{paramIndex} ", StringConverters.ToDatePattern(endDate,"yyyy-MM-dd"));
        }

五、in条件查询

String inShopCode = queryHash.get("inshopcode");
        if (!StringUtils.isEmpty(inShopCode)) {

//必须先将传过来的字符串转成一个数据,将数组以参数的形式传递
            List<String> str = Arrays.asList(inShopCode.split(","));
            conditionHash.put("shopAttendanceCode in (?{paramIndex}) ", str);
        }

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值