php - Laravel5 关联查询问题

 穿行来回间 发布于 2022-11-21 06:26

关联查询一致报错,不得已来SF麻烦各位大神帮我解答。

报错内容

ErrorException in 777fb9d9b961f2b2453d93297ba8a847 line 15:
Trying to get property of non-object (View: /home/millyn/www/x.x/resources/views/NewHome.blade.php)

我的对应文件如下

Avatar.php

 hasMany('App\Article');
    }
}

Article.php

 belongsTo('App\Avatar');
    }

}

Controller.php

    public function index()
    {
        $articles = Article::with('avatar')->latest()->paginate(8);
        return view('NewHome', compact('articles'));
    }

NewHome.blade.php

    

@foreach ($articles as $page)

{{ $page->title }}

@endforeach

{!!$articles->render()!!}

article_table.php

    public function up()
    {
        Schema::create('articles', function(Blueprint $table)
        {
            $table->increments('id');
            $table->string('title');
            $table->text('body')->nullable();
            $table->string('site')->nullable();
            $table->integer('avatars_id')->unsigned();;
            $table->integer('user_id');
            $table->string('nike')->nullable();
            $table->timestamps();

            $table->foreign('avatars_id')
                ->references('id')
                ->on('avatars')
                ->onDelete('cascade');
        });
    }

avatars_table.php

    public function up()
    {
        Schema::create('avatars', function(Blueprint $table)
        {
            $table->increments('id');
            $table->string('title');
            $table->string('url');
            $table->text('path');
            $table->timestamps();
        });
    }

我不知道是哪里有问题,不管怎么弄都是报错..希望大神帮忙看看.谢谢了.

6 个回答
  • 其实你只要一路跟 convention 走乖乖地建表就用 avatar_id 就不会出这些问题了。

    另外建议你 hasMany() 关系的时候也用复数

    public function articles() 
    {
        return $this->hasMany('App\Article');
    }
    

    这样写的时候自己也清楚了~

    2022-11-21 06:51 回答
  • 谢谢各位的答案,但我是最后自己解决的.
    我的解决方案和我挑选的答案是一个方法.
    我在
    Acticle.php里把内容改成了

        public function avatar()
        {
            return $this -> belongsTo('App\Avatar','avatars_id');
        }
    

    就行了,关于关联到模板上面的内容是
    {{$page->avatar->url}
    模型 关联方法 对应字段

    非常感谢各位,我也贴出正确解决我问题的方法.
    希望可以给以后遇到此类问题的朋友一个解决方案.

    2022-11-21 06:51 回答
  • 应该是你的调用关联用错了

    <img src="{{$page->avatars_id->url}}" alt="" width="180px">
    

    这里应该用

    {{$page->avatar->url}}
    

    因为你这里用的是

    $articles = Article::with('avatar')->latest()->paginate(8);
    

    如果你要改变映射的名字,需要

    $articles = Article::with(array('avatars_id'=>function(){/*映射的关系*/}))->latest()->paginate(8);
    

    这之后你要改变很多

    2022-11-21 06:51 回答
  • 看第15行输出的是哪个变量,然后dd打印变量,根据问题再逐步排解。

    2022-11-21 06:51 回答
  • 你可以dd($articles)来看看,相信在relations这一个上面会是null,总感觉你的relationship声明好奇怪

    2022-11-21 06:51 回答
  • php//打印下你查询的SQL语句看看
     public function article()
        {
            return $this -> hasMany('App\avatar','id','avatars_id');
        }
    
        public function avatar()
        {
            return $this -> belongsTo('App\App\Article','avatars_id','id');
        }
    
    2022-11-21 06:51 回答
撰写答案
今天,你开发时遇到什么问题呢?
立即提问
热门标签
PHP1.CN | 中国最专业的PHP中文社区 | PNG素材下载 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有