where
liên kết tham số thứ 3 và xử lý nó thường là một chuỗi, trừ khi bạn yêu cầu nó không làm như vậy bằng cách sử dụng câu lệnh thô. DB::raw
hoặc whereRaw
sẽ làm việc cho bạn:
return User::join('squad_user', 'users.id', '=', 'squad_user.user_id')
->join('seasons', 'squad_user.squad_id', '=', 'seasons.squad_id')
->where('squad_user.join_time', '<=', DB::raw('seasons.end_time'))
->where(function ($query)
{
$query->where('squad_user.leave_time', '>=', DB::raw('seasons.start_time'))
->orWhereNull('squad_user.leave_time');
})
->where('seasons.id', 3)
->get(['users.*']);