Download the PHP package gnahotelsolutions/laravel-query-cache without Composer
On this page you can find all versions of the php package gnahotelsolutions/laravel-query-cache. It is possible to download/install these versions without Composer. Possible dependencies are resolved automatically.
Download gnahotelsolutions/laravel-query-cache
More information about gnahotelsolutions/laravel-query-cache
Files in gnahotelsolutions/laravel-query-cache
Package laravel-query-cache
Short Description Query caching for Laravel 6+
License MIT
Informations about the package laravel-query-cache
Laravel Query Cache
This package is forked from dwightwatson/rememberable for flexibility in our company projects. Thank you for your package Dwight Watson ❤️
Laravel Query Cache is an Eloquent trait for Laravel that adds remember()
query methods. This makes it super easy to cache your query results for an adjustable amount of time.
It works by simply remembering the SQL query that was used and storing the result. If the same query is attempted while the cache is persisted it will be retrieved from the store instead of hitting your database again.
Installation
Install using Composer, just as you would anything else.
The easiest way to get started with Eloquent is to create an abstract App\Model
which you can extend your application models from. In this base model you can import the rememberable trait which will extend the same caching functionality to any queries you build off your model.
Now, just ensure that your application models from this new App\Model
instead of Eloquent.
Alternatively, you can simply apply the trait to each and every model you wish to use remember()
on.
Usage
Using the remember method is super simple. Just pass the number of seconds you want to store the result of that query in the cache for, and whenever the same query is called within that time frame the result will be pulled from the cache, rather than from the database again.
Cache tags
If you want to tag certain queries you can add cacheTags('tag_name')
to your query. Please notice that cache tags are not supported by all cache drivers.
Cache prefix
If you want a unique prefix added to the cache key for each of your queries (say, if your cache doesn't support tagging), you can add prefix('prefix')
to your query.
Alternatively, you can add the $rememberCachePrefix
property to your model to always use that cache prefix.
Cache driver
If you want to use a custom cache driver (defined in config/cache.php) you can add cacheDriver('cacheDriver')
to your query.
Alternatively, you can add the $rememberCacheDriver
property to your model to always use that cache driver.
Model wide cache tag
You can set a cache tag for all queries of a model by setting the $rememberCacheTag
property with an unique string that should be used to tag the queries.
Relationships
Validating works by caching queries on a query-by-query basis. This means that when you perform eager-loading those additional queries will not be cached as well unless explicitly specified. You can do that by using a callback with your eager-loads.
Always enable
You can opt-in to cache all queries of a model by setting the $rememberFor
property with the number of seconds you want to cache results for. Use this feature with caution as it could lead to unexpected behaviour and stale data in your app if you're not familiar with how it works.
Cache flushing
Based on the architecture of the package it's not possible to delete the cache for a single query. But if you tagged any queries using cache tags, you are able to flush the cache for the tag:
If you used the $rememberCacheTag
property you can use the method without a parameter and the caches for the tag set by $rememberCacheTag
are flushed:
Skipping cache
If you need to disable cache for a particular query, you can use the dontRemember
method:
All versions of laravel-query-cache with dependencies
illuminate/database Version ^6.0|^7.0|^8.0|^9.0|^10.0
illuminate/support Version ^6.0|^7.0|^8.0|^9.0|^10.0