I have web application using JPA. This entity manager keeps bunch of entites and suddenly I update the database from other side. I use MySQL and I use PhpMyAdmin and change some row.
How to tell entity manager to re-synchronize, e.g. to forgot all the entites in cache?
I know there is refresh(Object)
method, but is there any possibility how to do refreshAll()
or something what results in this?
It is sure this is expensive operation but if it has to be done.
entityManager.getEntityManagerFactory().getCache().evictAll()
Refresh
is something different since it modifies your object. This line will just empty the cache
, so if you fetch objects changed outside the entity manager, it will do an actual database query instead of using the outdated cached
value.
I had a similar issue and the evictAll()
line above worked for me.
Alternatively, the @Cache
annotation on the entity class worked too, with the benefit of being able to control caching parameters:
@Cache(coordinationType=CacheCoordinationType.INVALIDATE_CHANGED_OBJECTS)
See: http://wiki.eclipse.org/EclipseLink/Examples/JPA/Caching
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With