Обертка кеша для модели БД

Я пытался найти лучший способ создать оболочку кэша для всех моделей. Таким образом, весь просмотр БД выполняется через модель, но модель решает, следует ли сохранять результаты в кеше.

Например, когда я ищу пользователя по электронной почте, я хочу сделать что-то вроде User->getByEmail('test@exmaple.com');

Моя модель User будет содержать функцию, которая выглядит примерно так

public static function getByEmail($email) {
$cache = self::cacheFetch($email);
if($cache) {
return $cache;
}
// DB lookup to get data
self::cacheStore($email, $data);
return $data;
}

cacheFetch а также cacheStore определяются как черты. Имя приложения и имя таблицы добавляются к ключу кэша, чтобы избежать столкновения ключей.

Как мне выполнить поиск в базе данных в модели?

Есть ли лучший способ добиться того, что я пытаюсь сделать здесь?

2

Решение

На самом деле вам нужна только одна функция, cacheFetch, Эта функция проверяет, находятся ли запрашиваемые данные в кеше, и если нет, загружает данные из базы данных.

Это небольшой пример того, как функция может работать:

protected function cacheFetch($email)
{
$slug = 'db_' . self::getTable() . '_' . $email;

// Try fetching data from cache
if (cache()->has($slug)) {
return cache($slug);
}

// Fetch data from database and put in cache
$data = self::where('email', $email)->get();
cache()->put($slug, $data, 60);

return $data;
}
0

Другие решения

Других решений пока нет …

По вопросам рекламы ammmcru@yandex.ru
Adblock
detector