Laravel 5.6 - 一对多关系

时间:2018-06-04 15:39:04

标签: php laravel eloquent

我正在学习laravel和php。我有一个只有1种语言选项的成员对象,但有多种语言选项可供选择。 成员对象是我的主要对象。我想测试一下我是否正确设置了我的关系但是在测试时看不到所需的结果(我应该只看到语言字段中选择的语言,而不是每个成员的所有列属性,如下所示) 。所以这是我的show.blade.php文件的输出:

enter image description here

这是我的show.blade.php文件:

@extends('layouts.master')

@section('title', $member->name)

@section('content')
    <h1>Member Details: </h1>
    <p>Name: {{$member->name}}</p>
    <p>Surname: {{$member->surname}}</p>
    <p>ID Nr: {{$member->id_number}}</p>
    <p>Mobile Nr: {{$member->mobile_number}}</p>
    <p>Email: {{$member->email}}</p>
    <p>D.O.B: {{$member->date_of_birth}}</p>
    <p>Language:{{$member->language}}</p>
    <p>Created At: {{$member->created_at}}</p>
    <div class="page-header">
        <a href="{{action('MemberController@edit', $member->id)}}" class="btn btn-info">Edit</a>
    </div>
@endsection

这是我的语言表迁移文件:

public function up()
    {
        Schema::create('languages', function (Blueprint $table) {
            $table->increments('id');
            $table->integer('member_id')->unsigned();
            $table->string('name');
            $table->timestamps();
        });

        Schema::table('languages', function(Blueprint $table) {
            $table->foreign('member_id')->references('id')->on('members');
        });
    }

    /**
     * Reverse the migrations.
     *
     * @return void
     */
    public function down()
    {
        Schema::table('languages', function(Blueprint $table) {
            $table->dropForeign('languages_member_id_foreign');
        });
        Schema::dropIfExists('languages');
    }

这是我的成员表迁移文件:

public function up()
    {
        Schema::table('members', function (Blueprint $table) {
            $table->string('name');
            $table->string('surname');
            $table->string('id_number')->unique();
            $table->string('mobile_number');
            $table->string('email');
            $table->date('date_of_birth');
        });
    }

    /**
     * Reverse the migrations.
     *
     * @return void
     */
    public function down()
    {
        Schema::table('members', function (Blueprint $table) {
            $table->dropColumn('name');
            $table->dropColumn('surname');
            $table->dropColumn('id_number')->unique();
            $table->dropColumn('mobile_number');
            $table->dropColumn('email');
            $table->dropColumn('date_of_birth');
        });
    }

最后我的会员模特:

class Member extends Model
{
    public function language() {
        return $this->hasMany('App\Language');//('Language') = name of the Language Model
    }
}

我哪里错了?

1 个答案:

答案 0 :(得分:4)

您看到对象的JSON表示的原因是因为当您放置{{$member->language}}时,您在代码中要求的就是这一切。这代表整个App\Language对象。

尝试使用{{$member->language->first()->name}}来指定您只要求对象的name变量。

要显示所有语言,您需要使用以下代码循环遍历$member->language集合:

@foreach ($member->language as $language)
    {{ $language->name }}
@endforeach