首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >返回author.username等于$username的所有帖子

返回author.username等于$username的所有帖子
EN

Stack Overflow用户
提问于 2017-03-16 19:14:42
回答 2查看 70关注 0票数 1

我有一个与用户有这种关系的posts模型:

代码语言:javascript
复制
public function author()
{
    return $this->belongsTo(User::class, 'user_id');
}

我正在构建一个搜索函数,我有以下代码

代码语言:javascript
复制
public function index(Request $request)
{
    $search = $request->search;
    $filter = $request->filter;

    $append = array();

    $posts = Post::with('author')->with('categories')->latest();

    if($search){
        switch ($filter) {
            case 'username':
                $posts->author->where('username', 'LIKE', '%'. $search . '%');
            break;
        }
        $append += array('search' => $search);
        $append += array('filter' => $filter);
    }

    $posts = $posts->paginate(3);
    $posts->appends($append);

    return view('core.blog.posts.index', compact('posts'));
}

我得到了

未定义的属性:照明\数据库\雄辩\Builder::$author

如何根据作者的用户名添加在哪里查找作者?我必须能够在if情况下添加此条件。

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2017-03-16 21:21:31

您希望使用whereHas()来实现基于关系的搜索。这将只返回带有用户名的作者的帖子。

代码语言:javascript
复制
switch ($filter) {
    case 'username':
        $posts->whereHas('author', function($q) use($search) {
            $q->where('username', 'LIKE', '%'. $search . '%');
        });
    break;
}
票数 1
EN

Stack Overflow用户

发布于 2017-03-16 19:36:11

更新

如果需要有条件的where,可以这样做:

代码语言:javascript
复制
$postSelector = Post::with('categories');
if($search){
switch ($filter) {
    case 'username':
        $postSelector->with(['author' => function($q) use($search) {
            $q->where('username', 'LIKE', '%'. $search . '%');
        }]);
    break;
}

$posts = $postSelector->get();
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/42842968

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档