Как остановить Doctrine 2 от кеширования результата в Symfony 2?
Я хочу иметь возможность получить существующую версию объекта, чтобы я мог сравнить его с последней версией. Например. Редактируя файл, я хочу знать, изменилось ли значение с момента его нахождения в базе данных.
$entityManager = $this->get('doctrine')->getEntityManager();
$postManager = $this->get('synth_knowledge_share.manager');
$repository = $entityManager->getRepository('KnowledgeShareBundle:Post');
$post = $repository->findOneById(1);
var_dump($post->getTitle()); // This would output "My Title"
$post->setTitle("Unpersisted new title");
$existingPost = $repository->findOneById(1); // Retrieve the old entity
var_dump($existingPost->getTitle()); // This would output "Unpersisted new title" instead of the expected "My Title"
Кто-нибудь знает, как я могу обойти это кэширование?
Ответы
Ответ 1
Это нормальное поведение.
Doctrine хранит ссылку на извлеченные объекты в EntityManager, чтобы она могла вернуть объект по его идентификатору без выполнения другого запроса.
Вы можете сделать что-то вроде:
$entityManager = $this->get('doctrine')->getEntityManager();
$repository = $entityManager->getRepository('KnowledgeShareBundle:Post');
$post = $repository->find(1);
$entityManager->detach($post);
// as the previously loaded post was detached, it loads a new one
$existingPost = $repository->find(1);
Но помните об этом, поскольку объект $post был отсоединен, вы должны использовать метод → merge(), если хотите снова его сохранить.
Ответ 2
Вы также можете использовать метод refresh
, который обновляет постоянное состояние сущности из базы данных, переопределяя любые локальные изменения, которые еще не были сохранены.
Что-то вроде:
$entityManager = $this->get('doctrine')->getEntityManager();
$repository = $entityManager->getRepository('KnowledgeShareBundle:Post');
$post = $repository->find(1);
$entityManager->refresh($post);
теперь $post содержит последнюю версию из базы данных.