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