Laravel 5.5与一对多关系的多对多关系

时间:2017-10-04 20:57:17

标签: php mysql laravel migration

我正在开发一个项目,其中一个帐户只能有一个主要用户,但有多个普通用户。我正在尝试确定如何区分用户。以下是我目前的设置:

用户模型关系

public function accounts()
{
    return $this->belongsToMany('App\Models\Account', 'account_user');
}

帐户模型关系

主要帐户用户(一对多)

public function user()
{
    return $this->belongsTo(\App\Models\User::class);
}

普通帐户用户(多对多)

public function users()
{
    return $this->belongsToMany('App\Models\User', 'account_user');
}

在将要显示这些用户的页面中,我不确定如何拆分用户(主要用户与普通用户)。以下是我对表格的迁移。

USERS TABLE

Schema::create('users', function (Blueprint $table) {
    $table->increments('id');
    $table->string('name');
    $table->string('email')->unique();
    $table->string('password');
    $table->rememberToken();
    $table->timestamps();
});

帐户表

Schema::create('accounts', function (Blueprint $table) {
    $table->increments('id');
    $table->string('account_number');
    $table->integer('user_id')->unsigned()->index();
    $table->timestamps();

    $table->foreign('user_id')
        ->references('id')
        ->on('users')
        ->onDelete('cascade');
});

帐户用户(PIVOT TABLE)

Schema::create('account_user', function (Blueprint $table) {

    $table->integer('user_id')->unsigned();
    $table->foreign('user_id')->references('id')->on('users')->onDelete('cascade');

    $table->integer('account_id')->unsigned();
    $table->foreign('account_id')->references('id')->on('accounts')->onDelete('cascade');

});

我真的不明白 1.如何告知两个主要用户与普通用户。 2.在何处创建上述功能(模型,视图,服务......)。

感谢您的帮助,如果您需要更多信息,请与我们联系。

1 个答案:

答案 0 :(得分:0)

我不确定您的问题,但我会尝试回答。我也希望现在还不晚 帐户的主要用户可以通过以下方式获得:

Account::find($account)->user; //primary user

这样做可以吸引普通用户

Account::find($account)->users; //regular users

$ account是您要查找的主要用户和普通用户帐户的ID