Laravel SQL 或 Eloquent 高级查询

huangapple go评论70阅读模式
英文:

Laravel SQL Or Eloquent Advanced Query

问题

I need to make an advanced query in Laravel hopefully using Eloquent to make that a collection but a query builder or raw normal SQL query is acceptable.

我需要在Laravel中进行高级查询,最好使用Eloquent来将其转换为集合,但查询构建器或原始的SQL查询也可以接受。

I have users table with User model having relation:

我有一个名为"users"的表,使用User模型,具有以下关联:

public function roles()
{
   return $this->belongsToMany(Role::class,'users_roles');
}

I have roles table, with Role model having relation:

我有一个名为"roles"的表,使用Role模型,具有以下关联:

public function users()
{
   return $this->belongsToMany(User::class,'users_roles');
}

So, I have users_roles table with columns [user_id, role_id], so I can have users with multiple roles

因此,我有一个名为"users_roles"的表,具有列[user_id, role_id],因此我可以拥有具有多个角色的用户。

I want to get all users with roles different from a certain role, for example get all users that are all kind of roles except role of id 1

我想获取具有不同于特定角色的所有用户,例如获取除了id为1的角色之外的所有角色的用户。

how to do that?

如何做到这一点?

英文:

I need to make an advanced query in Laravel hopefully using Eloquent to make that a collection but a query builder or raw normal SQL query is acceptable.

I have users table with User model having relation:

public function roles()
{
   return $this->belongsToMany(Role::class,'users_roles');
}

I have roles table, with Role model having relation:

public function users()
{
   return $this->belongsToMany(User::class,'users_roles');
}

So, I have users_roles table with columns [user_id, role_id], so I can have users with multiple roles

I want to get all users with roles different from a certain role, for example get all users that are all kind of roles except role of id 1

how to do that?

答案1

得分: 0

你可以将一个 where 子句传递给 withWhereHas,以定义根据关联来返回哪些模型的规则,如下所示:

$usersWhereRoleIsNotOne = User::query()
    ->withWhereHas('roles', function(Builder $builder){
        $builder->whereNot('id', 1);
    })
    ->get();
英文:

You can pass a where clause to withWhereHas to defined rules on which models to return depending on relations, like so:

$usersWhereRoleIsNotOne = User::query()
    ->withWhereHas('roles', function(Builder $builder){
        $builder->whereNot('id', 1);
    })
    ->get();

答案2

得分: 0

I understand. Here is the translated code:

$roleId = 1;
$users = User::with($withArray)->whereDoesntHave('roles', function ($query) use ($roleId) {
    $query->where('roles.id', $roleId);
})->get();
英文:

My fix was:

$roleId = 1;
$users = User::with($withArray)->whereDoesntHave('roles', function ($query) use ($roleId) {
                    $query->where('roles.id', $roleId);
})->get();

huangapple
  • 本文由 发表于 2023年5月13日 21:04:41
  • 转载请务必保留本文链接:https://go.coder-hub.com/76242881.html
匿名

发表评论

匿名网友

:?: :razz: :sad: :evil: :!: :smile: :oops: :grin: :eek: :shock: :???: :cool: :lol: :mad: :twisted: :roll: :wink: :idea: :arrow: :neutral: :cry: :mrgreen:

确定