首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Laravel权限查询缓存

Laravel权限查询缓存
EN

Stack Overflow用户
提问于 2020-03-11 12:04:40
回答 1查看 375关注 0票数 0

我正在使用Laravel权限包(https://github.com/spatie/laravel-permission)来管理Laravel项目的角色权限。

在应用程序的每个页面上,我可以从Laravel调试器中看到以下两个查询正在运行。角色和权限没有那么频繁地更改,我想缓存这些查询。你能告诉我我该怎么做吗?

代码语言:javascript
复制
select `roles`.*, `model_has_roles`.`model_id` as `pivot_model_id`, `model_has_roles`.`role_id` as `pivot_role_id`, `model_has_roles`.`model_type` as `pivot_model_type` from `roles` inner join `model_has_roles` on `roles`.`id` = `model_has_roles`.`role_id` where `model_has_roles`.`model_id` = 1 and `model_has_roles`.`model_type` = 'App\Models\User'

select `permissions`.*, `model_has_permissions`.`model_id` as `pivot_model_id`, `model_has_permissions`.`permission_id` as `pivot_permission_id`, `model_has_permissions`.`model_type` as `pivot_model_type` from `permissions` inner join `model_has_permissions` on `permissions`.`id` = `model_has_permissions`.`permission_id` where `model_has_permissions`.`model_id` = 1 and `model_has_permissions`.`model_type` = 'App\Models\User'
EN

回答 1

Stack Overflow用户

发布于 2020-03-11 13:05:44

您可以使用this package缓存您的查询。

要在特定查询上启用缓存,您可以执行以下操作:

代码语言:javascript
复制
DB::cacheFor(now()->addHours(24))->raw('YOUR QUERY GOES HERE');
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/60629121

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档