Кеш-оболочка для модели БД

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

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

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

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

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

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

Стоит ли изучать PHP в 2023-2024 годах?
Стоит ли изучать PHP в 2023-2024 годах?
Привет всем, сегодня я хочу высказать свои соображения по поводу вопроса, который я уже много раз получал в своем сообществе: "Стоит ли изучать PHP в...
Symfony Station Communiqué - 7 июля 2023 г
Symfony Station Communiqué - 7 июля 2023 г
Это коммюнике первоначально появилось на Symfony Station .
Оживление вашего приложения Laravel: Понимание режима обслуживания
Оживление вашего приложения Laravel: Понимание режима обслуживания
Здравствуйте, разработчики! В сегодняшней статье мы рассмотрим важный аспект управления приложениями, который часто упускается из виду в суете...
Установка и настройка Nginx и PHP на Ubuntu-сервере
Установка и настройка Nginx и PHP на Ubuntu-сервере
В этот раз я сделаю руководство по установке и настройке nginx и php на Ubuntu OS.
Коллекции в Laravel более простым способом
Коллекции в Laravel более простым способом
Привет, читатели, сегодня мы узнаем о коллекциях. В Laravel коллекции - это способ манипулировать массивами и играть с массивами данных. Благодаря...
Как установить PHP на Mac
Как установить PHP на Mac
PHP - это популярный язык программирования, который используется для разработки веб-приложений. Если вы используете Mac и хотите разрабатывать...
2
0
105
1

Ответы 1

На самом деле вам нужна только одна функция, 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;
}

Другие вопросы по теме