Как остановить Doctrine 2 от кеширования результата в Symfony 2? - PullRequest
24 голосов
/ 31 октября 2011

Я хочу иметь возможность получить существующую версию сущности, чтобы я мог сравнить ее с последней версией.Например, редактируя файл, я хочу знать, изменилось ли значение с момента его нахождения в БД.

    $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"

Кто-нибудь знает, как мне обойти это кэширование?

Ответы [ 2 ]

42 голосов
/ 31 октября 2011

Это нормальное поведение.

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 (), если хотите сохранить ее снова.

12 голосов
/ 17 октября 2016

Вы также можете использовать метод refresh, который обновляет постоянное состояние объекта из базы данных, отменяя любые локальные изменения, которые еще не были сохранены. Что-то вроде:

$entityManager = $this->get('doctrine')->getEntityManager();
$repository = $entityManager->getRepository('KnowledgeShareBundle:Post');
$post = $repository->find(1);

$entityManager->refresh($post);

теперь $ post содержит последнюю версию из базы данных.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...