繁体   English   中英

如何将Laravel Scout和TNTSearch与关系数据库结合使用?

[英]How to use Laravel Scout & TNTSearch in combination with relational databases?

假设我有一个表'用户',我想用Laravel Scout搜索。 它有很多属性,其中有用户的爱好。

  • 用户的爱好没有直接放在users表中,
    但是通过关系表。 因此,为users表中的每个用户放置一个hobby-id。

  • 现在,当我搜索football, Laravel没有将其编入索引
    侦察。 只有业余爱好football的id被编入索引,但这当然不是我想要的。

任何人都知道我如何确保搜索football能让那些将足球作为业余爱好的用户回归?

谢谢你的时间!

您可以通过toSearchableArray()完全控制索引的确切内容,以便您可以执行某些操作。

class User extends Model
{
    use Searchable;

    // ...

    public function toSearchableArray()
    {
        return array_merge($this->toArray(), [
            'hobby' => $this->hobby === null ? '' : $this->hobby->name;
        ]);
    }

    // ...

    public function hobby()
    {
        return $this->belongsTo(Hobby::class);
    }

}

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM