Как я могу найти логическое значение, которое отображается в строке в JQuery Datatable?

У меня есть одно поле user_role, которое является логическим в базе данных. 1 = менеджер и 2 = обычный пользователь. Я отображаю в базе данных, как если бы user_role = 1, то он отображает менеджер и так далее. но проблема в том, что при поиске «Менеджер» поиск невозможен в поле user_role. но когда я ищу «1», это будет отображать все записи в поле менеджера.
вот мой код

$(function () {
var url = "{{ asset('managers') }}";
var table = $('#managers-table').DataTable({
bProcessing: true,
ordering: true,
serverSide: true,
paging: true,
bRetrieve: true,
autoWidth: false,
ajax: {
url: url
},
aaSorting: [[1, 'desc']],
columns: [
{data: 'user_id'},
{data: 'email'},
{data: 'username'},
{
"data": 'user_role',
"render": function (data) {
return data == 1 ? "<span>Manager</span>" : "<span>Normal user</span>";
}
},
]

});
});

и вот нам мой php код.

/**
* Display a listing of the Manager.
*
* @param Request $request
* @return Response
*/
public function index(Request $request)
{
$this->managerRepository->pushCriteria(new RequestCriteria($request));
if ($request->ajax()) {
return Datatables::of(Manager::IsDelete()->IsTestData()->get())->make(true);
}
return view('managers.index');
}

Как мне найти поле user_role? Пожалуйста, помогите, если кто-нибудь знает об этом.

2

Решение

Я получил решение. изменить запрос в коде PHP

 public function index(Request $request)
{
$this->managerRepository->pushCriteria(new RequestCriteria($request));
if ($request->ajax()) {
return Datatables::of(Manager::select(DB::raw("user_id, email, username,is_active,(CASE WHEN (user_role = 1) THEN 'Manager' ELSE 'Normal User' END) as user_role"))->IsDelete()->IsTestData()->get())->make(true);
}
return view('managers.index');
}
1

Другие решения

Других решений пока нет …

По вопросам рекламы [email protected]