在 Laravel 6 中缓存数据库查询结果的方法
在加快应用程序速度方面,缓存可能是最有效的。Laravel 预先安装了缓存驱动程序。因此你可以直接使用 Redis, Memcached 或者使用本地文件进行缓存操作。Laravel 附带了此功能。
这一次,我们将讨论直接从模型缓存 Eloquent 查询,从而使数据库缓存变的轻而易举。
这个包可以在 GitHub 找到,此文档将介绍该应用程序的所有要点。但是,这篇文章,我仅仅介绍缓存和清除缓存的知识。
安装
可以通过 Composer 安装
$ composer require rennokki/laravel-eloquent-query-cache
在你的模型中添加 use QueryCacheable :
use Rennokki\QueryCache\Traits\QueryCacheable;class Article extends Model { use QueryCacheable; ... }
默认情况下启动缓存行为
默认情况下,该包不开启查询缓存。为此,可以在模型中添加 $cacheFor 变量。
use Rennokki\QueryCache\Traits\QueryCacheable;class Article extends Model { use QueryCacheable; protected $cacheFor = 180; // 3 minutes }
每当执行一个查询时,缓存将会干预。如果此查询在缓存中为空,那么会去数据库中获取数据,并且缓存它,以便下次可以从缓存中获取。如果此查询存在于缓存中,那么直接返回。
// 数据库访问,查询结果存储在缓存中 Article::latest()->get();// 未访问数据库,查询结果直接从缓存中返回。 Article::latest()->get();
如果你只是想要避免命中缓存,你可以在命中最后一个方法之前使用 ->dontCache() 。
Article::latest()->dontCache()->firstOrFail();
启用逐个查询的缓存行为
另一种方法是,如果默认情况下的缓存机制并不是太好的选择,你可以启用逐个查询的缓存。
首先,从模型中移除变量 $cacheFor。
对于每个查询,你可以调用 ->cacheFor(...) 方法去指定你想缓存的那个查询。
Article::cacheFor(now()->addHours(24))->paginate(15);
用 tags 更好地组织缓存
一些缓存存储,像 Redis 或者 Memcached,提供了对 key 的标记支持。这很有用,因为我们可以在缓存中标记查询,并在需要时再通过 tag 使所需的缓存失效。
举一个简单的例子,如果我们要在更新一篇文章时使文章列表不进行缓存,你可以像这样写。
$articles = Article::cacheFor(60)->cacheTags(['latest:articles'])->latest()->get(); $article = Article::find($id); $article->update(['title' => 'My new title']); Article::flushQueryCache(['latest:articles']);
flushQueryCache
方法使用 latest:articles标记使缓存无效。如果其他的一些查询中没有被 latest:articles标记,那么将被保留缓存。
了解更多
有关此软件包的更多信息,请在GitHub 上查看该项目。
PS:Laravel缓存
1,Cache:put('key','val',10);设置缓存
键:key , 值:val 10:缓存时间十分钟
2,Cache:add('key','val',10);
设置缓存 key:键,val:值 10:缓存时间十分钟
(有返回值 : 已经有了缓存则返回false, 没有则返回true并缓存)
3,Cache:forever('key','val');永久缓存
4,Cache:has('key');判断缓存是否存在
5,Cache:get('key');获取缓存
6,Cache:pull('key');获取缓存一次并删除缓存
7,Cache:get('key');删除缓存,true删除成功,false删除失败
总结
以上所述是小编给大家介绍的在 Laravel 6 中缓存数据库查询结果的方法,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对我们网站的支持!
如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!
上一篇:PHP学习记录之面向对象(Object-oriented programming,OOP)基础【类、对象、继承等】
栏 目:PHP编程
下一篇:PHP设计模式之中介者模式(Mediator Pattern)入门与应用案例详解
本文标题:在 Laravel 6 中缓存数据库查询结果的方法
本文地址:https://www.xiuzhanwang.com/a1/PHPbiancheng/11037.html
您可能感兴趣的文章
- 04-02网页里php操作数据库 php网页例子
- 04-02php插入数据库为乱码 php连接数据库乱码
- 01-11在phpstudy集成环境下的nginx服务器下配置url重写
- 01-11Laravel 微信小程序后端搭建步骤详解
- 01-11Laravel框架Blade模板简介及模板继承用法分析
- 01-11Laravel 微信小程序后端实现用户登录的示例代码
- 01-11Laravel框架基础语法与知识点整理【模板变量、输出、include引入
- 01-11Laravel框架Eloquent ORM删除数据操作示例
- 01-11如何在centos8自定义目录安装php7.3
- 01-11Laravel框架Eloquent ORM修改数据操作示例
阅读排行
本栏相关
- 04-02php本站才可以请求数据 php本地数据库
- 04-02关于txt数据库php的信息
- 04-02php打印请求数据 php打印输出结果
- 04-02网页里php操作数据库 php网页例子
- 04-02php插入数据库为乱码 php连接数据库乱
- 04-02php数据库地址 phpstudy 数据库
- 04-02php数据库数据相加 php数据库添加数据
- 04-02数据权限架构思路php 数据权限设计方
- 04-02php数据库输入变量 php里输出数据库数
- 04-02php如何用导入数据 php用来导入其他文
随机阅读
- 01-10delphi制作wav文件的方法
- 04-02jquery与jsp,用jquery
- 01-10SublimeText编译C开发环境设置
- 01-11Mac OSX 打开原生自带读写NTFS功能(图文
- 08-05DEDE织梦data目录下的sessions文件夹有什
- 01-10使用C语言求解扑克牌的顺子及n个骰子
- 01-10C#中split用法实例总结
- 08-05织梦dedecms什么时候用栏目交叉功能?
- 08-05dedecms(织梦)副栏目数量限制代码修改
- 01-11ajax实现页面的局部加载