繁体   English   中英

Laravel 附加访问器意外地也添加了与响应的关系

[英]Laravel appending accessor unexpectedly also add relationship to response

感谢您抽出时间帮助我理解这个问题。

我有一个“Vehicle”类,如下所示:(为了保持简单,我删除了很多方法和可填充物)

<?php

namespace App;

use Illuminate\Database\Eloquent\Model;

use App\Trip;

class Vehicle extends Model
{
    public $fillable = [
       ...
    ];

    protected $appends = [
        'LastTrip'
    ];

    public function trips()
    {
        return $this->hasMany(Trip::class);
    }

    public function getLastTripAttribute()
    {
        return $this->trips->last();
    }
}

问题是当我从控制器返回此类的实例时。 它序列化了“旅行”关系,因此每次旅行都在我的响应中。

然而,这只发生在我尝试附加“LastTrip”访问器时。 如果我将其更改为以下内容,则问题不会持续存在

protected $appends = [
    #'LastTrip'
];

我只是想让它序列化“LastTrip”访问器。

我希望我把我的问题说清楚了,如果我可以应用任何进一步的信息,请告诉我。

谢谢你的帮助。

发生这种情况是因为您的访问器执行以下操作:

  1. 加载完整的行程关系
  2. 将 trips 集合中的最后一项设置为 last_trip 属性。

将您的代码更改为以下内容:

public function getLastTripAttribute()
{
    // If the relation is already loaded, avoid doing an extra SQL query
    if ($this->relationLoaded('trips')) {
        return $this->trips->last();
    // Otherwise, get the last trip from an SQL query.
    } else {
        return $this->trips()->orderByDesc('id')->first();
    }
}

编辑:

当您调用$this->trips->last()它会获取所有行程,然后将最后一个分配给 LastTrip。 但是如果你在“trips”之后使用括号,它只能从 db 获取 1 行,试试这个:

public function getLastTripAttribute()
{
    return $this->trips()->latest()->first();
}

或者

public function getLastTripAttribute()
{
    return $this->trips()->orderByDesc('id')->first();
}

暂无
暂无

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

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