laravel查询时间是否冲突(类似预定)

场景: 数据库有有两个字段.开始时间,和结束时间,指定一个时间段(a,b),a表示开始时间,a表示结束时间。看数据库中有没有与(a,b)冲突的时间段,有的话就返回那条记录。

解析:两个时间段相当于两个集合,不过是有顺序的集合。两个时间段有交集细分有四种情况。用sql直接判断无交集的语句可能也有,但是目前没有想到,只想到有交集的语句,如果返回不为空则表明有交集,否则没有交集。

环境:Laravel 5.7
php7.1.16
mysql5.7
废话不多say,直接上代码:

    public function checkRegionUse($start_time,$end_time){
        $positionuse=Position_use::WhereBetween('start_time', [$start_time, $end_time])
            ->orWhereBetween('end_time', [$start_time, $end_time])
            ->orwhere('start_time','<',$start_time)
            ->where('end_time','>',$end_time)
            ->orwhere('start_time','>',$start_time)
            ->get();
        if ($positionuse->isEmpty()){
            return false;
        }else{
            return $positionuse;
        }
    }

这段代码主要解决4种情况

1.startTime > a AND startTime < b

在这里插入图片描述
在这里插入图片描述

2.startTime < a AND endTime > b

在这里插入图片描述

3.endTime > a AND endTime < b

在这里插入图片描述

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值