首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Laravel Searchable属于

Laravel Searchable属于
EN

Stack Overflow用户
提问于 2020-08-08 16:50:35
回答 1查看 195关注 0票数 1

我正在使用由nicolaslopezj https://github.com/nicolaslopezj/searchable搜索的包,并且我试图做一个属于的关系,但是我在使用它时遇到了一些麻烦。

代码语言:javascript
复制
protected $searchable = [
    /**
     * Columns and their priority in search results.
     * Columns with higher values are more important.
     * Columns with equal values have equal importance.
     *
     * @var array
     */
    'columns' => [
        'products.title' => 10,
        'products.description' => 5,
    ],
    'joins' => [
        "brand" => ['products.brand_id', 'brands.id']
    ],
];

public function brand()
{
    return $this->belongsTo(Brand::class);
}

这里的问题是,当数据库表被称为“品牌”时,它试图获取数据库表“品牌”。但是,如果我将其更改为brands,我会得到一个与laravel的关系错误。所以我真的不知道该怎么做。文档也没有很好地解释它。希望能帮上忙,谢谢!

EN

回答 1

Stack Overflow用户

发布于 2020-08-08 18:18:14

考虑到注释中讨论的内容,原始问题的解决方案是更新Brand模型,方法是将protected $table变量设置为'brand',然后调整上面的变量以反映这一点。

这应该会解决你最初的关系错误问题,并保持代码的一致性,就像你在评论中提到的那样。

代码语言:javascript
复制
<?php

namespace App;

use Illuminate\Database\Eloquent\Model;

class Brand extends Model
{
    /**
     * The table associated with the model.
     *
     * @var string
     */
    protected $table = 'brand';
}

默认情况下,Laravel将始终假定数据库表是模型名称的复数形式。因此,如果您的模型是单数的,那么您应该假设它期望数据库表是复数形式,除非如上所述显式设置!

按如下所示调整其他代码,以引用brand.id而不是brands.id

代码语言:javascript
复制
protected $searchable = [
    /**
     * Columns and their priority in search results.
     * Columns with higher values are more important.
     * Columns with equal values have equal importance.
     *
     * @var array
     */
    'columns' => [
        'products.title' => 10,
        'products.description' => 5,
    ],
    'joins' => [
        "brand" => ['products.brand_id', 'brand.id']
    ],
];

public function brand()
{
    return $this->belongsTo(Brand::class);
}
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/63313477

复制
相关文章

相似问题

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