繁体   English   中英

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

[英]Laravel 5.5 Many-to-Many relationship with a One-to-Many relationship

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

用户模型关系

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');
}

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

用户表

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');
});

帐户用户(个人表格)

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.在何处创建以上功能(模型,视图中的服务,...)。

感谢您的帮助,如果您需要更多信息,请告诉我。

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

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

普通用户可以通过以下方式获得

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

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

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

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