我正在尝试连接特定用户角色使用的公司。具有特定角色的用户可以为多家公司“工作”。公司可以“雇用”多个用户。我有5个表(用户,role_user,角色,公司和company_user)
模特关系:
App\User:
public function roles()
{
return $this
->belongsToMany('App\Role')
->withTimestamps();
}
public function companies()
{
return $this
->belongsToMany('App\Company')
->withTimestamps();
}
App\Role:
public function users()
{
return $this
->belongsToMany('App\User')
->withTimestamps();
}
App\Companies:
public function users()
{
return $this->belongsToMany('App\User'); // with user_role ??
}
公司财务总监
public function edit(Request $request, $id) {
$company = Company::findOrFail($id);
$users = User::where('role_id',4)->pluck('username')->all(); // no role_id column
$users = User::pluck('username','id')->all(); // returns all users
return view('companies.edit', compact(['company','users']));
}
public function update(Request $request, $id) {
/* TODO */
}
修改视图
{!! Form::select('users[]', $users, null, ['class' => 'form-control', 'multiple' => 'multiple']) !!}
我想将具有特定用户角色的用户与这些公司签约。有没有办法设置关系或可能是范围?
奖金问题:)是否有一种简单的方法可以在下拉列表中显示连接值?名字+姓氏而不是用户名?
答案 0 :(得分:0)
也许不是最整洁的解决方案,但似乎有效:)
模型
public function scopeOfRole($query, $role) {
return $query->
join('role_user', 'role_user.user_id', '=', 'users.id')->
join('roles', 'roles.id', '=', 'role_user.role_id')->
select(
DB::raw('GROUP_CONCAT(users.first_name," ",users.last_name) as username'),
'users.id')->
where('roles.name', $role)->
groupBy('users.id');
}
的Controler
public function edit(Request $request, $id) {
$company = Company::findOrFail($id);
$users = User::OfRole('my role')->pluck('username','users.id')->all();
return view('companies.edit', compact(['company','users']));
}
编辑视图
{!! Form::select('users[]', $users, $company->users()->pluck('users.id'), ['class' => 'form-control', 'multiple' => 'multiple']) !!}