Обычно я использую @ Cache Hibernate (using = CacheConcurrencyStrategy.NONSTRICT_READ_WRITE) для кэширования класса @Entity, и это хорошо работает.
В JPA2 есть еще одна аннотация @Cacheable, которая похожа на ту же функциональность, что и @Cache Hibernate.Чтобы сделать мой класс сущности независимым от пакета hibernate, я хочу попробовать.Но я не могу заставить это работать.Каждый раз, когда простой запрос все еще попадает в БД.
Кто-нибудь может сказать мне, где что-то не так?Спасибо.
Класс сущности:
@Entity
//@Cache(usage = CacheConcurrencyStrategy.NONSTRICT_READ_WRITE)
@Cacheable(true)
public class User implements Serializable
{
// properties
}
Класс теста:
@RunWith(SpringJUnit4ClassRunner.class)
@ContextConfiguration(locations={"classpath:app.xml"})
@TransactionConfiguration(transactionManager="transactionManager")
public class UserCacheTest
{
@Inject protected UserDao userDao;
@Transactional
@Test
public void testGet1()
{
assertNotNull(userDao.get(2L));
}
@Transactional
@Test
public void testGet2()
{
assertNotNull(userDao.get(2L));
}
@Transactional
@Test
public void testGet3()
{
assertNotNull(userDao.get(2L));
}
}
Результат теста показывает каждый слой БД попаданий "get" (с hibernate.show_sql = true).
Persistence.xml:
<property name="hibernate.dialect" value="org.hibernate.dialect.MySQLDialect"/>
<property name="hibernate.show_sql" value="true"/>
<property name="hibernate.format_sql" value="true" />
<property name="hibernate.use_outer_join" value="true"/>
<property name="hibernate.cache.provider_class" value="org.hibernate.cache.SingletonEhCacheProvider"/>
<property name="hibernate.cache.use_second_level_cache" value="true"/>
<property name="hibernate.cache.use_query_cache" value="true"/>
Код JPA:
@Override
public T get(Serializable id)
{
return em.find(clazz, id);
}