我需要按日期对集合进行排序,然后按距离对具有相同日期的行进行排序。
当我处理状态和距离时,我完成了相同的过程,这很容易,因为我知道我要对集合进行排序的状态值,而现在有了日期,我无法确定其值。
这是我的状态为
的工作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
}
答案 0 :(得分:0)
此Github issue上的某人提出以下建议:
$result->sortBy(function($item) {
return [$item->date_end, $item->distance_km];
});