Mybatis查询数据时间区间是否存在交集

需求

  • 需求 : 有时候项目需要插入的数据不能出现时间区间的重合

SQL查询

SELECT 
*
FROM table_1
WHERE 
active=1
AND 
(start_time >= {start} AND start_time <= {end} 
OR (start_time <= {start} AND end_time >= {end} ) 
OR (end_time >= {start} AND end_time <= {end} )) 
limit 1

MybatisPlus实现

 LambdaQueryWrapper<HotzoneEntity> wrapper = new QueryWrapper<TAB>()
                .lambda()
                .last(" limit 1")
                .eq(TAB::getStatus, StatusEnum.START.getStatus());
wrapper.and(obj ->
                obj.ge(TAB::getStartTime, start).le(TAB::getStartTime, end)
               .or(k -> k.le(TAB::getStartTime, start).ge(TAB::getEndTime, end))
               .or(m -> m.ge(TAB::getEndTime, start).le(TAB::getEndTime, end))
);
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值