首页 > 解决方案 > 在 Eloquent 模型中使用急切加载的问题

问题描述

我有 2 个模型及其关系。第一类称为“Documento”:

class Documento extends Model
{
    protected $table = 'documento';
    protected $primaryKey = 'cod_documento';

    public function emisor()
    {
        return $this->belongsTo('App\Emisor', 'cod_emisor', 'cod_emisor');
    }
}

第二个称为“Emisor”:

class Emisor extends Model
{
    protected $table = 'emisor';
    protected $primaryKey = 'cod_emisor';

    public function documentos()
    {
        return $this->hasMany('App\Documento', 'cod_emisor', 'cod_emisor');
    }
}

模型关系是一对多的(一个发射器有很多文档,一个文档只有一个发射器)。

在 Thinker 中,我尝试从文档中获取发射器,并且效果很好:

>>> Documento::find(1)->emisor->name
=> "Emisor Name"

但是当我尝试在文档中执行 Eager Loading the emisor 时,“失败”:

>>> Documento::find(1)->with('emisor')->count();
=> 94041

我期望一个结果,但查询返回 94041 个文档。

为什么会这样?如何获得一个带有嵌套发射器的文档?

标签: laravel-5eloquenteager-loadinglaravel-5.7eloquent-relationship

解决方案


交换find()with()

$documento = Documento::with('emisor')->find(1);

或者使用延迟加载

$documento = Documento::find(1)->load('emisor');

使用现有模型实例:

$documento->load('emisor');

您会得到这个意外结果,因为Documento::find(1)->with('emisor')创建了一个查询所有 Documento条目的新查询。因此 的总数94041


推荐阅读