在 Laravel 6 中緩存數據庫查詢結果的方法

發布時間:2019-12-12 10:04 來源:互聯網 當前欄目:網站服務器

在加快應用程序速度方面,緩存可能是最有效的。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并緩存)

  • 1、
  • 2、
  • 3、
  • 4、
  • 5、
  • 6、
  • 7、
  • 8、
  • 9、
  • 10、
  • 11、
  • 12、
  • 13、
  • 14、
  • 15、
  • 16、
  • 17、
  • 18、
  • 19、
  • 20、
  • 21、
  • 22、
  • 23、
  • 24、
  • 25、
  • 1、
  • 2、
  • 3、
  • 4、
  • 5、
  • 6、
  • 7、
  • 8、
  • 9、
  • 10、
  • 11、
  • 12、
  • 13、
  • 14、
  • 15、
  • 16、
  • 17、
  • 18、
  • 19、
  • 20、
  • 21、
  • 22、
  • 23、
  • 24、
  • 25、