Laravel雄辩的多次查询

时间:2019-01-29 10:09:23

标签: php mysql laravel eloquent laravel-query-builder

我需要按日期对集合进行排序,然后按距离对具有相同日期的行进行排序。

当我处理状态和距离时,我完成了相同的过程,这很容易,因为我知道我要对集合进行排序的状态值,而现在有了日期,我无法确定其值。

这是我的状态为

的工作
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

}

1 个答案:

答案 0 :(得分:0)

此Github issue上的某人提出以下建议:

$result->sortBy(function($item) {
      return [$item->date_end, $item->distance_km];
});