PHP   发布时间:2022-04-04  发布网站:大佬教程  code.js-code.com
大佬教程收集整理的这篇文章主要介绍了口才:基于关系筛选记录大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。

我正在尝试让没有所有者角色的特定于客户的用户,但它还会跳过没有任何角色的用户.用户可以具有一个或多个角色.我想让所有用户具有多个角色或根本没有任何角色,但是如果用户包含所有者角色,则仅应忽略该用户.

注意:我使用的是spatie / laravel-permission,它从模型中获取用户角色,并具有角色中间表

这是我的范围查询

public function scopeForCompany(EloquentBuilder $query, String $customerId): EloquentBuilder
    {
        $query->where(function (EloquentBuilder $q) {
           $q->doesntHave('roles');
           $q->orHas('roles');
        });

        $query->whereHas('roles', function (EloquentBuilder $q) {
            $q->wherenotin('name', ['owner']);
        });


        return $query->where('customer_id', $customerId);;
    }

这是测试

public function it_apply_query_scope_to_get_customer_specific_users_only(): void
    {
        $model = new User;

        // create non customer users
        \factory(User::class, 2)->create();

        $customer = \factory(Customer::class)->create();
        foreach (['owner', 'admin', 'user'] as $rolE) {
            $role = \factory(Role::class)->create(['name' => $role]);
            $user = \factory(User::class)->create(['customer_id' => $customer->id]);
            $user->roles()->save($rolE);
        }

        $scopedUsers = $model->newQuery()->forCompany($customer->id)->get();
        $nonScopedUsers = $model->newQuery()->get();

        static::assertCount(2, $scopedUsers); // Failed asserTing that actual size 0 matches expected size 2.
        static::assertCount(5, $nonScopedUsers);
    }

调试:这是行查询

"SELEct * from `users` where (not exists (SELEct * from `roles` inner join `model_has_roles` on `roles`.`id` = `model_has_roles`.`role_id` where `users`.`id` = `model_has_roles`.`model_uuid` and `model_has_roles`.`model_type` = ?) or exists (SELEct * from `roles` inner join `model_has_roles` on `roles`.`id` = `model_has_roles`.`role_id` where `users`.`id` = `model_has_roles`.`model_uuid` and `model_has_roles`.`model_type` = ?)) and exists (SELEct * from `roles` inner join `model_has_roles` on `roles`.`id` = `model_has_roles`.`role_id` where `users`.`id` = `model_has_roles`.`model_uuid` and `model_has_roles`.`model_type` = ? and `name` not in (?)) and `customer_id` = ? and `users`.`deleted_at` is null"

这是我首先尝试但没有奏效的

return $query->whereHas('roles', function (EloquentBuilder $query): void {
       $query->wherenotin('name', ['owner']);
})->where('customer_id', $customerId);

任何帮助将不胜感激谢谢

解决方法:

您需要做一些“或”逻辑才能做到这一点.我将查询分为三部分.

声明:“我想让所有用户都具有多个角色”

$query->has('roles', '>=', 2);

接下来,您希望所有人都没有角色:“或根本没有角色”.

$query->doesntHave('roles');

最后,您的查询正确地过滤出角色不能成为所有者的位置.

$query->whereHas('roles', function (EloquentBuilder $query): void {
   $query->wherenotin('name', ['owner']);
})

将所有内容放在一起进行类似的操作,并使用sub where查询.要正确执行您想要的“或”逻辑.

$query->where(function($builder){
    $builder->has('roles', '>=', 2);
    $builder->whereHas('roles', function (EloquentBuilder $query): void {
       $query->wherenotin('name', ['owner']);
    })
});

$builder->orDoesntHave('roles');

在伪逻辑语句中,这看起来类似于:

(roles.each.name != 'owner' && count(roles) >= 2) || empty(roles)

让我们看看这是否对您有帮助,否则发布构建器的tosql()并弄清楚.这是一个相当复杂的查询生成器逻辑.

大佬总结

以上是大佬教程为你收集整理的口才:基于关系筛选记录全部内容,希望文章能够帮你解决口才:基于关系筛选记录所遇到的程序开发问题。

如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。
标签: