2017 © Pedro Peláez
 

library query-cache-builder

This package is caching every single query per request, to make sure that you will never duplicate your query again.

image

geeky/query-cache-builder

This package is caching every single query per request, to make sure that you will never duplicate your query again.

  • Wednesday, June 20, 2018
  • by TheGeeky
  • Repository
  • 4 Watchers
  • 4 Stars
  • 32 Installations
  • PHP
  • 0 Dependents
  • 0 Suggesters
  • 2 Forks
  • 0 Open issues
  • 3 Versions
  • 0 % Grown

The README.md

Laravel Query Cache Builder

If you are using Barryvdh's Debug Bar and you're seeing tons of duplicate queries, and you simply have no time to track them all down., (*1)

Screenshot, (*2)

The package is caching all duplicates queries and it makes sure that you will never be executed the same query again, by overriding the method runSelect exsists in Illuminate\Database\Query\Builder that runs in every select query in Laravel, and we're going to cache every query by it's SQL and it's Bindings., (*3)

So instead of excuting a query, we will cache it as a key and it's results as a value., (*4)

If a query excutes, we will check if the query executed once before so we will retrieve the cached value or we will excute the query then cache it., (*5)

Screenshot, (*6)

Installation

1- Install using composer:, (*7)

 composer require geeky/query-cache-builder

2- Add a custom Cache Driver. We're doing this so that we don't mess with any existing Cache logic you might already be using. In ~/config/cache.php add below cache stores array :, (*8)

Note: you can use what you want of cache drivers.

'stores' => [
'cache-builder' => [
'driver' => 'file',
'path'   => storage_path('framework/cache')
  ]
]

3- If you don't use auto-discovery, add the ServiceProvider to the providers array in config/app.php, (*9)

Geeky\Database\CacheBuilderServiceProvider::class

4- Copy the package config to your local config with the publish command:, (*10)

php artisan vendor:publish --provider="Geeky\Database\CacheBuilderServiceProvider"

This will publish the cachebuilder config file that gives you the ability to enable cahcing queries and the time you want to cache them., (*11)

Note: In case you used an array cache driver the quires will be cached in-memory Cache store that just stores everything inside an array. This is typically wiped at the end of each request,as once the application gives a response, this is naturally freed from memory. so it doesn't matter if you edit the minutes to 0 or any integer number., (*12)

<?php

return [

  'enable'  => true,

  'minutes' => 1, // 0 or null will cache all quieris forever

];

Usage

Use the CacheQueryBuilder trait in any model you want to use this feature., (*13)

<?php

namespace App;

use Geeky\Database\CacheQueryBuilder;
use Illuminate\Database\Eloquent\Model;

class SomeModel extends Model
{
    use CacheQueryBuilder;
}

Use the below command if you want to flush the cache of our custom store, (*14)

php artisan cache-builder:clear

The Versions

20/06 2018

dev-master

9999999-dev

This package is caching every single query per request, to make sure that you will never duplicate your query again.

  Sources   Download

MIT

by Mohamed Emad

database laravel cache query cache laravel duplicate query query cache builder

20/06 2018

1.1

1.1.0.0

This package is caching every single query per request, to make sure that you will never duplicate your query again.

  Sources   Download

MIT

by Mohamed Emad

database laravel cache query cache laravel duplicate query query cache builder

13/06 2018

1.0

1.0.0.0

This package is caching every single query per request, to make sure that you will never duplicate your query again.

  Sources   Download

MIT

by Mohamed Emad

database laravel cache query cache laravel duplicate query query cache builder