我正在开发一个项目,其中一个帐户只能有一个主要用户,但有多个普通用户。我正在尝试确定如何区分用户。以下是我目前的设置:
用户模型关系
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.在何处创建上述功能(模型,视图,服务......)。
感谢您的帮助,如果您需要更多信息,请与我们联系。
答案 0 :(得分:0)
我不确定您的问题,但我会尝试回答。我也希望现在还不晚 帐户的主要用户可以通过以下方式获得:
Account::find($account)->user; //primary user
这样做可以吸引普通用户
Account::find($account)->users; //regular users
$ account是您要查找的主要用户和普通用户帐户的ID