Как указать поле выбора с помощью ленивого оператора? - PullRequest
0 голосов
/ 19 ноября 2018

Как указать поле выбора с помощью оператора lazy?

Order::with("country", "pacient")->get();

Как указать поля выбора для модели Order и зависимых отношений, таких как:

order.id, country.name, pacient.name,...

Ответы [ 2 ]

0 голосов
/ 19 ноября 2018

Сделайте это более детальным и «лауреатским» способом: используя Ресурсы API .

Поколение

php artisan make:resource OrderResource

Настройка

приложение / Http / Ресурсы / OrderResource.php

<?php

namespace App\Http\Resources;

use Illuminate\Http\Resources\Json\JsonResource;

class User extends JsonResource
{
    /**
     * Transform the resource into an array.
     *
     * @param  \Illuminate\Http\Request  $request
     * @return array
     */
    public function toArray($request)
    {
        return [
            'order_id' => $this->id,
            'country_name' => $this->country->name,
            'patient' => $this->patient->name,
            // ...
        ];
    }
}

Используйте

В контроллере вы можете сделать:

приложение / Http / Контроллеры / MyCoolController.php

use App\Http\Resources\OrderResource;

// ...

public function myCoolMethod()
{
    // get your posts:
    $orders = Order::all();

    return OrderResource::collection($posts);
}
0 голосов
/ 19 ноября 2018

для выбранных определенных столбцов при активной загрузке, и это будет работать

Order::with('country:id,name', 'pacient:id,name')->get();

, просто убедитесь, что вы добавляете идентификатор отношения при извлечении реляционных столбцов

, если вы хотите свободный запрос, тогда

DB::table('orders')
    ->join('countries', 'countries.id', '=', 'orders.country_id')
    ->join('pacient', 'pacient.id', '=', 'orders.pacient_id')
    ->select('order.id', 'country.name', 'pacient.name')
     ->get();
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...