Обертка кеша для модели БД - PullRequest
0 голосов
/ 17 декабря 2018

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

Например, когда я ищу пользователя по электронной почте, я хочу сделать что-то вроде 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 определены как черты.Имя приложения и имя таблицы добавляются к ключу кэша, чтобы избежать столкновения ключей.

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

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

1 Ответ

0 голосов
/ 17 декабря 2018

На самом деле вам нужна только одна функция, 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;
}
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...