Заказать вложенный Eager Загрузка Eloquent Laravel - PullRequest
1 голос
/ 03 апреля 2020

У меня проблема с красноречивым запросом. Я использую готовую загрузку (один-ко-многим Polymorphi c Relationship) для сортировки 'historyable.date', JSON ниже.

[
   {
      "product_id":12,
      "product_name": "Product C",
      "historyable_type":"App\\Delivery",
      "historyable":{
         "id":2,
         "date":"0303\/0404\/2020",
         "for":"Customer A",
         "created_at":"2020-04-02T09:46:48.000000Z",
      }
   },
   {
      "product_id":1,
      "product_name": "Product A",
      "historyable_type":"App\\Transfer",
      "historyable":{
         "id":1,
         "date":"0202\/0404\/2020",
         "for":"First Balance ****",
         "created_at":"2020-04-02T07:30:45.000000Z",
      }
   },
   {
      "product_id":11,
      "product_name": "Product B",
      "historyable_type":"App\\Delivery",
      "historyable":{
         "id":2,
         "date":"0303\/0404\/2020",
         "for":"Customer B",
         "created_at":"2020-04-02T09:46:48.000000Z",
      }
   }
]

И я пытаюсь получить такой результат

[
   {
      "product_id":1,
      "product_name": "Product A",
   },
   {
      "product_id":12,
      "product_name": "Product C",
   },
   {
      "product_id":11,
      "product_name": "Product B",
   }
]

Можно ли работать с вложенной отложенной загрузкой Laravel?

Модель продукта

public function track() {
   return $this->hasMany('App\History');
}

История модели

public function historyable(){
   return $this->morphTo()->orderBy('date', 'desc');
}

Контроллер продукта

public function json_history(Product $product) {
   $data = $product->with('track.historyable')
   ->where('id', $product->id)
   ->first();
   return $data->track;
}

У меня есть такая база данных

Products Table
#id
#name

Histories Table
#product_id
#product_name
#historyable_id
#historyable_type

Deliveries Table
#id
#date
#for

Transfers Table
#id
#date
#for

Ответы [ 2 ]

0 голосов
/ 03 апреля 2020
public function json_history(Product $product) {
   $data = Product::with('track.historyable')
           ->where('id', $product->id)
           ->first();

   $arr = $data->track->toArray();

   $date = array();
   $create = array();
   foreach ($arr as $key => $row)
   {
      $date[$key]  = $row['historyable']['date'];
      $create[$key]  = $row['historyable']['created_at'];
   }

   array_multisort($date, SORT_DESC, $arr);
   array_multisort($create, SORT_DESC, $arr);

  return $arr;
 }

Я не знаю, но это работает для меня .. но я все еще нахожу более короткий путь для этого ..

0 голосов
/ 03 апреля 2020

Использование OrderBY

public function json_history(Product $product) {
   $data = $product->with('track.historyable')
   ->where('id', $product->id)
   ->orderBy('product_id', 'DESC')
   ->first();
   return $data->track;
}

РЕДАКТИРОВАТЬ

public function historyable(){
   return $this->morphTo()->orderBy('date', 'ASC');
}
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...