dongshanji3102 2017-08-02 21:45
浏览 164
已采纳

Laravel Eloquent检查多个orWhere语句,然后在两个日期之间进行排序

I am trying to run a query in which I find out what positions a person held between two dates. Here is what I have so far:

$startDate = Carbon::parse($start)->toDateString();
      $endDate = Carbon::parse($end)->toDateString();

$user = Auth::id();

    $Positions = Position::whereBetween('shootDate', array($startDate, $endDate))->where('photographer_id', $user)->orWhere('photoEditor_id', $user)->orWhere('videographer_id', $user)
            ->orWhere('videoEditor_id', $user)->orWhere('scheduler_id', $user)->orWhere('drone_id', $user)->orWhere('webpage_id', $user)
            ->orWhere('flyer_id', $user)->orWhere('zillow_id', $user)->get();

I know this isn't going to work because of the orWhere statements basically override the whereBetween command but I don't know how to get around this.

I need to either get the list between the two dates, then see if the user held ANY of those positions, or get All of the positions that the user has, AND THEN only include those between the two dates. Does anyone know how I can accomplish this? Currently, this query returns all of the positions the user held even those outside of the dates.

  • 写回答

1条回答 默认 最新

  • douyuan4357 2017-08-02 22:50
    关注

    I understand from your question that you need a query like this

    SELECT * 
    FROM position
    WHERE (
        photographer_id = $user OR
        photoEditor_id = $user OR
        videographer_id = $user OR
        videoEditor_id = $user OR
        scheduler_id = $user OR
        drone_id = $user OR
        webpage_id = $user OR
        flyer_id = $user OR
        zillow_id = $user
        ) AND
        shootDate BETWEEN $startDate AND $endDate
    

    I made some test with other tables and you can try something like this

    $Positions = Position::where(function($query){
                $query->where('photographer_id', $user);
                $query->orWhere('photoEditor_id', $user);
                $query->orWhere('videographer_id', $user);
                $query->orWhere('videoEditor_id', $user);
                $query->orWhere('scheduler_id', $user);
                $query->orWhere('drone_id', $user);
                $query->orWhere('webpage_id', $user);
                $query->orWhere('flyer_id', $user);
                $query->orWhere('zillow_id', $user);
            })
            ->whereBetween('shootDate', array($startDate, $endDate))
            ->get();
    

    Hope this can help!

    I'll wait your feedback

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥15 深度学习中的画图问题
  • ¥15 java报错:使用mybatis plus查询一个只返回一条数据的sql,却报错返回了1000多条
  • ¥15 Python报错怎么解决
  • ¥15 simulink如何调用DLL文件
  • ¥15 关于用pyqt6的项目开发该怎么把前段后端和业务层分离
  • ¥30 线性代数的问题,我真的忘了线代的知识了
  • ¥15 有谁能够把华为matebook e 高通骁龙850刷成安卓系统,或者安装安卓系统
  • ¥188 需要修改一个工具,懂得汇编的人来。
  • ¥15 livecharts wpf piechart 属性
  • ¥20 数学建模,尽量用matlab回答,论文格式