0

我有一个用户角色模型,使用 Laravel 4,其中一个用户可以有许多角色,使用 Eloquent。我可以使用以下代码轻松访问链接到用户的所有角色:

class User extends Model {
    protected $table = 'user';
    protected $fillable = array('name');

    public function rolesLinked() {
        return $this->hasMany('App\UserRoleLink', 'user_id');
    }
}

我一直在尝试获取未链接到用户的角色,以在选择框中的特定用户页面上显示。使用这个函数,包含在 User 类中。

public function rolesNotLinked() {
    $user = this
    $roles = Roles::whereDoesntHave('App\UserRoleLink',function($query) use ($user){
        $query->where('user_id',$user->id);
    });
}

问题是,调用此函数会给我以下错误。

Call to undefined method Illuminate\Database\Query\Builder::App\UserRoleLink()

我尝试使用 has with < 1 来查看函数是否有问题,但是在阅读了这个和在线源代码之后,函数调用几乎完成了我尝试过的操作。

我的函数调用有问题,还是我在某处搞砸了配置?

作为参考,这是我的其他模型类:

class UserRoleLink extends Model{
     protected $table = 'user_role_link';
     protected $fillable = array('role_id','user_id);

    public function role() {
        return $this->hasOne('App\Role', 'role_id');
    }
}

class Role extends Model{
     protected $table = 'role';
     protected $fillable = array('name');
}

编辑:我发现我在复制粘贴时被填充物搞砸了。它没有解决问题,但我想这更近了一步。

4

1 回答 1

0

要使用whereDoesntHave方法,您必须在角色模型中添加关系。

class Role extends Model{
     protected $table = 'role';
     protected $fillable = array('name');

     public function UserRoles() {
         return $this->hasMany('App\UserRoleLink', 'id');
     }
}


此外,whereDoesntHave方法的第一个参数不是模型,而是关系的函数:

public function rolesNotLinked() {
    $user = this
    $roles = Roles::whereDoesntHave('UserRoles',function($query) use ($user){
        $query->where('user_id',$user->id);
    });
}
于 2016-05-06T15:49:59.737 回答