【发布时间】:2026-02-01 17:30:01
【问题描述】:
我无法从相关表中检索数据。
有 3 个模型(表)。
- 用户
- 啁啾(有'user_id'作为外键)
- 单击(具有“chirp_id”作为外键)
然后我想从 Chirp 模型中检索 User & Click 的数据。 于是我写了:
啁啾.php
namespace App;
use Illuminate\Database\Eloquent\Model;
class Chirp extends Model
{
public $timestamps = false;
protected $guarded = [];
public function user()
{
return $this->belongsTo('App\User');
}
public function clicks()
{
return $this->hasMany('App\Click');
}
}
HomeController.php
class HomeController extends Controller
{
public function index()
{
$chirps = Chirp::with(['user','clicks'])
->orderBy('posted_at', 'desc')
->get();
return view('home', ['chirps' => $chirps]);
}
}
home.blade.php
@foreach($chirps as $chirp)
<div>
<div>by
<b>{{ $chirp->user->name }}</b>
on
<small>{{ $chirp->posted_at }}</small>
</div>
<div>
<p>{{ $chirp->text }}</p>
<p>{{ $chirp->click->ip_address }}</p>
</div>
</div>
@endforeach
在 home.blade.php 中,{{ $chirp->click->ip_address }} 无法检索并出现错误“Facade\Ignition\Exceptions\ViewException Trying to get property 'ip_address' of non-object”
但是,如果我删除它,我可以正确检索{{ $chirp->user->name }}。
为什么我不能从 Chirp 模型中检索 Click 模型,而我可以从 Chirp 模型中检索 User 模型?
谢谢。
【问题讨论】:
-
可以有多次点击..所以你必须使用foreach
-
在
hasMany关系上,您将获得集合而不是模态。因此,您将不得不遍历数据。它在 Laravel 文档中有很好的记录。 HasMany
标签: laravel eloquent-relationship