我需要按日期对集合进行排序,然后按距离对具有相同日期的行进行排序。
当我处理状态和距离时,我完成了相同的过程,这很容易,因为我知道我要对集合进行排序的状态值,现在有了日期,我无法解决它的值。
这是我的工作状态:
if($result){
if($data['status'] == true){
$result = $result->sortBy('listing.status')->values();
if($sqlDistance != null){
$res = $result->where('distance_km', '!=', null);
$resNull = $result->where('distance_km', '=', null)->all();
$statusNotPlanned = $res->where('listing.status', 0)->sortBy('distance_km')->values()->all();
$statusPlanned = $res->where('listing.status', 1)->sortBy('distance_km')->values()->all();
$statusDone = $res->where('listing.status', 2)->sortBy('distance_km')->values()->all();
$res = array_merge($statusNotPlanned, $statusPlanned, $statusDone);
$result = array_merge($res, $resNull);
}
return response()->json(['status' => 200,'type' => 'status', 'data' => $data, 'events' => (is_object($result)) ? array_slice($result->toArray(),$data['offset']*10,10) : array_slice($result,$data['offset']*10,10), 'cities' => $cities]);
}
现在我需要做同样的事情,但是要用日期而不是状态:
这是我现在的位置:
elseif($data['date'] == true ) {
$result = $result->sortBy('date_end')->values();
$res = $result->where('date_end', '!=', null)->all();
$resNull = $result->where('date_end', '=', null)->all();
$result = array_merge($res, $resNull);
return response()->json(['status' => 200,'type' => 'date', 'data' => $data, 'events' => (is_object($result)) ? array_slice($result->toArray(),$data['offset']*10,10) : array_slice($result,$data['offset']*10,10), 'cities' => $cities]);
}
这是我当前的输出:
{
date_end : 12/07/2018,
distance : 320km
},
{
date_end : 12/08/2018,
distance : 110km
},
{
date_end : 12/08/2018,
distance : 100km
},
{
date_end : 12/08/2018,
distance : 120km
},
{
date_end : 12/09/2018,
distance : 480km
}
这是所需的输出:
{
date_end : 12/07/2018,
distance : 320km
},
{
date_end : 12/08/2018,
distance : 100km
},
{
date_end : 12/08/2018,
distance : 110km
},
{
date_end : 12/08/2018,
distance : 120km
},
{
date_end : 12/09/2018,
distance : 480km
}
最佳答案
Github issue上的某人提出以下建议:
$result->sortBy(function($item) {
return [$item->date_end, $item->distance_km];
});
关于php - Laravel Eloquent 多次查询,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/54418539/