Laravel在表中进行雄辩的搜索 [英] Laravel Eloquent search inside related table

查看:41
本文介绍了Laravel在表中进行雄辩的搜索的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我有一个具有多个角色的用户列表,希望我的Ajax搜索方法可以在此结果集中进行搜索(user1具有用户角色和admin角色).所以我这样写了我的请求:

I'm having a list of users which have multiple roles and Iwish that my ajax search method could search inside this resultset (user1 have user role and admin role). So Iwrote my request like this :

$usersData = User::where('name', 'like', $queryString . '%')
        ->orWhere('email', 'like', $queryString . '%')
        ->orWhere('username', 'like', $queryString . '%')
        ->when($limit > 0 || $offset > 0, function ($usersData) use ($limit, $offset) {
            $usersData->take($limit)->skip($offset);
        })
        ->with('roles:name')->whereHas('roles',function($query) use($queryString){
            $query->where('roles.name','like',$queryString.'%');
        })
        ->get();

但这行不通,您不知道出什么问题了吗?谢谢.

But it doesn't work have you an idea what is the problem ? Thanks.

推荐答案

使用 orWhereHas()代替 whereHas():

->orWhereHas('roles', function($query) use($queryString){
    $query->where('name', 'like', '%' . $queryString. '%');
})

这篇关于Laravel在表中进行雄辩的搜索的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆