繁体   English   中英

Laravel Eloquent不返回所有相关模型

[英]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.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM