search - Laravel scout (meilisearch-driver) 搜索多对多关系
问题描述
我有一个多对多的关系,我会用 laravel scout (meilisearch-driver) 对这种关系进行搜索。
我的模型:
受益人.php
<?php
namespace App\Models;
use Laravel\Scout\Searchable;
use Illuminate\Database\Eloquent\Model;
class Beneficiary extends Model
{
use Searchable;
protected $table = 'beneficiaries';
public function contacts() {
return $this->belongsToMany('App\Models\Contact', 'beneficiary_contacts', 'beneficiary_id', 'contact_id');
}
protected function makeAllSearchableUsing($query) {
return $query->with('contacts');
}
}
联系方式.php
<?php
namespace App\Models;
use Laravel\Scout\Searchable;
use Illuminate\Database\Eloquent\Model;
class Contact extends Model
{
use Searchable;
protected $table = 'contacts';
public function beneficiaries() {
return $this->belongsToMany('App\Models\Beneficiary', 'beneficiary_contacts', 'contact_id', 'beneficiary_id');
}
protected function makeAllSearchableUsing($query) {
return $query->with('beneficiaries');
}
}
我需要通过搜索字符串找到特定“受益人”的“联系人”。我在我的控制器中试过这个:
public function getBeneficiaryContactsBySearch(Request $request, $id) {
...
$contacts = Beneficiary::findOrFail($id)->contacts()->search($search)->paginate($request->per_page);
...
}
但我得到错误“ Call to undefined method Illuminate\Database\Eloquent\Relations\BelongsToMany::search()
”。
有没有办法用 laravel scout 做到这一点?
谢谢。
解决方案
推荐阅读
- bash - 将 bash 脚本输出重定向到不包括菜单的日志文件
- django - 如何在 django 中将静态添加到我的脚本中
- java - 为什么Java中的for循环是否存在不会有任何区别
- mysql - 如何在 Rails 应用程序中更改数据库
- javascript - 什么将在 NodeJS 中返回带有等待的 for 循环?
- python - 对数据集执行 k-means 聚类后分析聚类的技术
- docker - NuxtJS 开发服务器上客户端的连接错误问题
- android - 在 android 中使用 Room 时出错:错误 2067 (SQLITE_CONSTRAINT_UNIQUE)
- reactjs - React 如何更改具有关键属性的组件?
- php - 当我尝试使用 symfony 创建实体时出现 Aborted 错误消息