[英]Laravel Eloquent not returning all related models
我有一个不返回相关模型的模型,Call和CallType是我的模型,具有一对一关系。
通话模型
public function calltype(){
return $this->hasOne('App\CallType');
}
CallType模型
public function call(){
return $this->belongsTo('App\Call');
}
CallsController索引方法
$calls = Call::all();
$user_group = Group::find(Auth::user()->group_id);
return view('settings.calls.index', compact('calls', 'user_group'));
calls.blade.php
@foreach($calls as $call)
<tr>
<td>{{$call->call_code}}</td>
<td>{{$call->call_name}}</td>
<td>{{$call->calltype->type}}</td>
</tr>
@endforeach
通话迁移
Schema::create('calls', function (Blueprint $table) {
$table->increments('id');
$table->integer('call_type_id')->unsigned();
$table->string('call_name');
$table->string('call_code');
$table->date('start_date');
$table->date('end_date');
$table->string('target_audience')->nullable();
$table->text('description')->nullable();
$table->timestamps();
$table->softDeletes();
$table->foreign('call_type_id')->references('id')->on('call_types');
});
呼叫类型迁移
Schema::create('call_types', function (Blueprint $table) {
//
$table->increments('id');
$table->string('type');
$table->timestamps();
});
我收到此错误:
试图获取非对象的属性
当我做dd($calls)
它没有相关模型。 我究竟做错了什么? 请帮忙。
尝试这个
在刀片
@if(isset($calls))
@foreach($calls as $call)
<tr>
<td>{{$call->call_code}}</td>
<td>{{$call->call_name}}</td>
<td>{{$call->calltype->type}}</td>
</tr>
@endforeach
@endif
确保索引不是calls
而是$calls
在clontroller中
return view('calls')->with(['calls'=>$calls,'user_group'=> $user_group]);
首先,您应该使用预先加载来最小化数据库查询。
更改:
$calls = Call::all();
成
$calls = Call::with('calltype')->get();
您收到的错误是因为可能没有为每个呼叫设置呼叫类型,所以您应该在模板中进行更改:
<td>{{$call->calltype->type}}</td>
成
<td>{{ $call->calltype ? $call->calltype->type : '-' }}</td>
我想到了。 我应该在CallType上有一个hasMany,因为每个CallType可以分配许多呼叫。 应该是这样的:
CallType模型
public function calls()
{
return $this->hasMany('App\Call');
}
通话模式
public function call_type(){
return $this->belongsTo('App\CallType');
}
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.