Fun*_*k91 3 php laravel eloquent laravel-5 laravel-query-builder
编辑:为清楚起见,这是Laravel 5.8。
这是我正在使用的HR应用程序。
他们要求提供一份报告,以显示迟到的人。当然可以,我认为没有问题。
因此,我有一个带有一些自定义参数的表单,用户可以在其中输入以下内容:start_date,end_date,工资和一组部门。
public function show()
{
request()->validate([
'start_date' => 'required|date|before_or_equal:today'
]);
$start = Carbon::parse(request('start_date'));
$end = request('end_date') ? Carbon::parse(request('end_date')) : today();
$wage = request('wage');
$departments = request('departments');
$query = EmployeePunch::with([
'employee' => function($query) use ($wage, $departments) {
// IF I UN COMMENT THESE, IN THE FILTER BLOCK BELOW, THE EMPLOYEE BECOMES UNDEFINED.
// if($wage != null) {
// $query->where('hourly', $wage);
// }
// if($departments) {
// $query->whereIn('department_id', $departments);
// }
},
'employee.group',
'employee.department'
])
->whereBetween('punch_time', [$start->startOfDay(), $end->endOfDay()])
// only care about punch in for the day
->where('type', 1);
$results = $query->get();
$latePunches = $results->filter(function ($i) {
$day = strtolower($i->punch_time->format('D'));
$startTime = Carbon::parse(sprintf('%s %s',
$i->punch_time->format('d-m-Y'),
$i->employee->group[$day.'_start_time'])
);
return $i->punch_time->isAfter($startTime)
&& $i->punch_time->diffInMinutes($startTime) >= 5;
});
return view('hr.employeeLateReport.show', compact('latePunches'));
}
Run Code Online (Sandbox Code Playgroud)
因此,我的问题在于我急于加载,无法解决。如果我取消对急切加载员工的筛选器的注释,则在代码块末尾的筛选器块中,$i->employee变得不确定。如果省略过滤器,则一切正常。我检查了正在生成的查询,一切看起来都很不错。
任何帮助将不胜感激。
这是关系方法
public function punches()
{
return $this->hasMany(EmployeePunch::class);
}
public function group()
{
return $this->belongsTo(Group::class);
}
public function department()
{
return $this->belongsTo(Department::class)->withDefault();
}
Run Code Online (Sandbox Code Playgroud)
public function employee()
{
return $this->belongsTo(Employee::class);
}
Run Code Online (Sandbox Code Playgroud)
小智 5
尝试使用whereHas和嵌套whereBetween:
$query = EmployeePunch::with([
'employee' => function($query) use ($wage, $departments) {
if($wage != null) {
$query->where('hourly', $wage);
}
if($departments) {
$query->whereIn('department_id', $departments);
}
},
'employee.group',
'employee.department'
])->whereHas('employee', function($q) use($start, $end) {
$q->whereBetween('punch_time', [$start->startOfDay(), $end->endOfDay()]);
})->where('type', 1);
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
50 次 |
| 最近记录: |