首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Laravel追加访问器意外地也添加了响应的关系。

Laravel追加访问器意外地也添加了响应的关系。
EN

Stack Overflow用户
提问于 2020-02-21 21:41:52
回答 2查看 46关注 0票数 2

谢谢你抽出时间来帮助我理解这个问题。

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

代码语言:javascript
复制
<?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‘访问器时,才会发生这种情况。如果我将其更改为以下内容,问题就不会持续存在

代码语言:javascript
复制
protected $appends = [
    #'LastTrip'
];

我只想让它序列化'LastTrip‘访问器。

我希望我把我的问题说清楚,如果我可以申请任何资料,请告诉我。

谢谢你的帮助。

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2020-02-21 22:01:06

编辑:

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

代码语言:javascript
复制
public function getLastTripAttribute()
{
    return $this->trips()->latest()->first();
}

代码语言:javascript
复制
public function getLastTripAttribute()
{
    return $this->trips()->orderByDesc('id')->first();
}
票数 2
EN

Stack Overflow用户

发布于 2020-02-21 22:07:12

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

relationship

  • set将trips集合中的最后一项加载为属性。

将代码更改为:

代码语言:javascript
复制
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();
    }
}
票数 3
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/60346575

复制
相关文章

相似问题

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