QueryDSL 复杂查询及函数

qyerydsl版本 4.1.4

执行mysql函数

1. 日期函数过滤

 StringTemplate dateExpr = Expressions.stringTemplate("DATE_FORMAT({0},'%Y-%m-%d')",qCalendar.serviceTime);
        BooleanExpression where = qCalendar.hosId.eq(query.getHosId())
            .and(qCalendar.accountId.eq(query.getAccountId()))
            .and(dateExpr.goe(query.getStartDate()))
            .and(dateExpr.loe(query.getEndDate()));

2. 使用find_in_set代替正则 (正则没有找到合适方法)

// REGEXP '(^|,)(1|2)(,|$)'
                BooleanExpression aTrue = Expressions.booleanTemplate(
                    "FIND_IN_SET({0},{1})",
                    query.getScheduleType(),
                    // scheduleType数据库是 1,2,3这种格式
                    qSnScheduleSync.scheduleType.stringValue()
                );
                where = where.and(aTrue.isTrue());
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值