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