dongzhen6554 2015-09-03 16:03
浏览 512
已采纳

Laravel lmutator $ this-> attributes返回'Undefined index:id'

So, I'm trying to add an attribute (rating) to a model.

So far I did this:

    public function getRatingAttribute()
    {

        return $this::join('reviews', 'accounts.id', '=' , 'reviews.account_id')
        ->where('accounts.id', $this->attributes['id'])
        ->select(DB::raw('SUM(reviews.rating) / COUNT(reviews.id)'))->pluck('rating');
    }

But it returns Undefined index: id

The strange is if I do a dd on $this->attributes it shows all array attributes, including id.

What am I doing wrong and how can I get the attribute value?

  • 写回答

2条回答 默认 最新

  • dongyuan9149 2015-09-03 20:28
    关注

    Try leveraging the relation and just select the aggregate.

    public function getRatingAttribute()
    {
    
        return $this->reviews()
            ->selectRaw('AVG(reviews.rating) as aggregate')
            ->pluck('aggregate');
    
    }
    

    Update: Changed this to use the built in AVG to avoid the divide by zero.

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

悬赏问题

  • ¥15 C++ yoloV5改写遇到的问题
  • ¥20 win11修改中文用户名路径
  • ¥15 win2012磁盘空间不足,c盘正常,d盘无法写入
  • ¥15 用土力学知识进行土坡稳定性分析与挡土墙设计
  • ¥70 PlayWright在Java上连接CDP关联本地Chrome启动失败,貌似是Windows端口转发问题
  • ¥15 帮我写一个c++工程
  • ¥30 Eclipse官网打不开,官网首页进不去,显示无法访问此页面,求解决方法
  • ¥15 关于smbclient 库的使用
  • ¥15 微信小程序协议怎么写
  • ¥15 c语言怎么用printf(“\b \b”)与getch()实现黑框里写入与删除?