Как отображать данные с помощью отношения "многие ко многим" яджры в laravel?

Я использую данные Yajra. Я хочу отображать данные и фильтровать данные с именем президента У меня есть 3 таблицы

1- Planes = id, title, description.

2- presidents = id, P_name.

3- Plane_president = plane_id , president_id

Модель самолета:

public function president()
    {
        return $this->belongsToMany(President::class);
    }

Модель президента:

public function planes()
{
    return $this->belongsToMany(Plane::class);
}

Мой контроллер:

public function index(Request $request)
    {
    if ($request->ajax()) {
            $query = Plane::with('presidents')->selectRaw('distinct planes.*');
            return $this->dataTable
                ->eloquent($query)
                ->addColumn('P_name', function (Plane $plane) {
                    return $plane->presidents->map(function($president) {
                        return str_limit($president->P_name);
                    })->implode('<br>');
                })
                ->make(true);
        }

        return view('planes.index');
    }

js код:

  <script type="text/javascript">
      $('#search').DataTable({
        processing: true,
        serverSide: true,
        ajax: '{{ route("plane.index") }}',
        columns: [
            {data: 'id', name: 'id'},
            {data: 'main_point', name: 'main_point'},
            {data: 'presidents[, ].P_name', name: 'president'},
        ]
    });
    </script>

У меня эта ошибка

message "Undefined property: App\\Http\\Controllers\\PlaneController::$dataTable"

Как решить эту ошибку?


person Tabish    schedule 17.09.2020    source источник


Ответы (2)


используйте DataTables::, чтобы получить datatable, а вам не хватало ->rawColumns(['p_name']), я добавил это

if ($request->ajax()) {
    $plane = Plane::with('presidents')->selectRaw('distinct planes.*')->get();
    return \DataTables::of($plane)
        ->addColumn('p_name', function ($plane) {
            return implode(', ', $plane->presidents->pluck('P_name')->toArray());
        })
        ->rawColumns(['p_name'])
        ->make(true);
}

в javascript

<script type="text/javascript">
      $('#search').DataTable({
        processing: true,
        serverSide: true,
        ajax: '{{ route("plane.index") }}',
        columns: [
            {data: 'id', name: 'id'},
            {data: 'main_point', name: 'main_point'},
            {data: 'p_name', name: 'p_name'}, // manipulate data of this column in server side here just echo like this
        ]
    });
</script>
person Kamlesh Paul    schedule 17.09.2020

Вам необходимо пройти его, как показано ниже.

return datatables()->eloquent($query);

Пожалуйста, проверьте документ. и для отображения имени президента я бы предложил.

implode(', ', $plane->presidents->pluck('P_name')->toArray())
person Dilip Hirapara    schedule 17.09.2020
comment
У меня возникает эта ошибка, когда я хочу найти данные DataTables warning: table id=search - Exception Message: SQLSTATE[42S22]: Column not found: 1054 Unknown column 'planes.presidents' in 'where clause' (SQL: select count(*) as aggregate from (select distinct planes.* from planes`, где (LOWER (_2 _._ 3_) LIKE% j% or LOWER (_4 _._ 5_) LIKE% j% or LOWER (_6 _._ 7_) LIKE% j%)) count_row_table ) ` - person Tabish; 17.09.2020