Как искать столбец, который я добавил в Laravel Yajra Datatables с отношениями?

Итак, я использую Yajra Datatables, чтобы сделать мои данные доступными.

Я добавил дополнительный столбец, как показано ниже, чтобы он мог отображать имя пользователя из отношения.

->addColumn('customer_name', function (Order $order){
                return $order->user->name;
            })

Хотя этот столбец отображается в таблице данных, я не могу его найти. Ниже приведен полный код функции:

public function viewDTPending(){
        $store= Auth::user()->store;
        $pending = Order::where('store', $store)->where('status', 'Pending')->orderBy('user_id')->groupBy('order_id', 'status', 'order_branch', 'user_id', 'created_at', 'updated_at');
        return Datatables::of($pending)
            ->addColumn('customer_name', function (Order $order){
                return $order->user->name;
            })
            ->editColumn('created_at', function (Order $order){
                    return $order->created_at->diffForHumans();
                })
            ->make(true);
    }

И ниже код ajax:

<script>
    $(function() {
        $('#table').DataTable({
            processing: true,
            serverSide: true,
            ajax: '{{ url('getPendingOrdersDT') }}',
            columns: [
                { data: 'order_id', name: 'order_id' },
                { data: 'user_id', name: 'user_id' },
                { data: 'customer_name', name: 'customer_name' },
                { data: 'status', name: 'status' }
            ]
        });
    });
</script>

Как я могу заставить его выполнять поиск в столбце customer_name?


person ravexu    schedule 03.11.2020    source источник
comment
Order модель имеет отношение принадлежности к User модели?   -  person sta    schedule 03.11.2020
comment
@sta да, потому что данные даже показывают. Просто я не могу фильтровать   -  person ravexu    schedule 03.11.2020


Ответы (2)


Попробуйте "Нетерпеливую загрузку":

$pending = Order::with('user:id,name')->where('store', $store)->where('status', 'Pending')->orderBy('user_id')->groupBy('order_id', 'status', 'order_branch', 'user_id', 'created_at', 'updated_at');
   return Datatables::of($pending)
     ->addColumn('customer_name', function ($row){
          return $row->user['name'];
   })
person sta    schedule 03.11.2020
comment
хм, это тоже не работает. просто получаю кучу ошибок при фильтрации. - person ravexu; 03.11.2020
comment
Привет, так что то, что вы показали, действительно сработало. Единственное, чего не хватало, - это то, что я неправильно обращался к нему в ajax. В ajax мне пришлось сделать { data: 'user.name', name: 'user.name' }, Возможно, вы захотите отредактировать это как ответ для людей в будущем. Большое спасибо. - person ravexu; 03.11.2020
comment
Надеюсь, я правильно отредактирую? если да, то вы можете получить доступ с помощью { data: 'customer_name', name: 'customer_name' }, - person sta; 03.11.2020
comment
Вы можете удалить это addColumn, если хотите, без него вы можете получить доступ через { data: 'user.name', name: 'user.name' }, потому что у вас есть данные для загрузки with('user:id,name') - person sta; 03.11.2020
comment
Да, я удалил addColumn, потому что получил его через нетерпеливую загрузку user.name. Это правильный способ и исправление для меня, - person ravexu; 03.11.2020

Вы должны ввести имя таблицы вместе со столбцом.

Пример: name: 'users.id'

Мы используем этот метод для поиска ajax в той же системе

или простой код:

    $objects = Model::query()
        ->leftJoin('curs', 'cur.id', '=', 'model.cur_id')
        ->select([
            'models.id',
            'models.address',
            'models.tag',
            'curs.title_en',
        ]);

    return Datatables::of($objects)
        ->addColumn('actions', function ($model) {
            return 'action'
        })
        ->make(true);
person Akbar Rahmanii    schedule 03.11.2020
comment
Я уже пробовал это, а также users.name, однако получаю сообщение об ошибке: DataTables warning: table id=table - Exception Message: с запросом SQL - person ravexu; 03.11.2020
comment
DB :: table ('firstData') - ›rightJoin ('joinTableName', 'firstData.id', '=', 'joinTableName.firstDataId') Используйте приведенный выше пример, чтобы узнать, есть ли у вас ошибка - person Akbar Rahmanii; 03.11.2020