1.hibernate.cfg.xml配置如下
<!-- 设置二级缓存供应商 -->
<property name="cache.provider_class">
org.hibernate.cache.EhCacheProvider
</property>
<!-- 开启二级缓存 -->
<property name="cache.use_second_level_cache">
true
</property>
<!-- 开启二级缓存统计机制 -->
<property name="generate_statistics">
true
</property>
2 .Privilege的hbm.xml配置如下
<hibernate-mapping>
<class name="com.back.domain.privilege.Privilege" table="PRIVILEGE">
<cache usage="read-only"/>
<id name="id" type="java.lang.Integer">
<column name="ID" />
<generator class="increment" />
</id>
<property name="role" type="java.lang.String">
<column name="ROLE" />
</property>
<set name="uers" table="user_privilege" cascade="save-update">
<key>
<column name="PID" />
</key>
<many-to-many class="com.back.domain.user.User" column="UID" />
</set>
</class>
</hibernate-mapping>
3.使用二级缓存
SessionFactory sessionFactory=SessionFactoryUtils.getSesessionFactory();
Session session=sessionFactory.openSession();
Query query=session.createQuery("from com.back.domain.privilege.Privilege");
List<Privilege> list=query.list();
for(Privilege user:list){
System.out.println(user.getRole());
}
System.out.println("二级缓存有:"+sessionFactory.getStatistics().getEntityLoadCount());
session.close();
System.out.println("--------------------");
System.out.println("二级缓存有:"+sessionFactory.getStatistics().getEntityLoadCount());
Session session2=sessionFactory.openSession();
Query query2=session2.createQuery("from com.back.domain.privilege.Privilege where id=1");
Iterator<Privilege> iterator=query2.iterate();
while(iterator.hasNext()){
System.out.println(iterator.next().getRole());
}
System.out.println("二级缓存有:"+sessionFactory.getStatistics().getEntityLoadCount());
session2.close();
}
- 问题? 二级缓存已经有了值,为什么还是从数据库中又去获取了,我换成其他类都没这个问题,唯独这个Privilege有这个问题。而且本来Privilege表有4条记录,也就是二级缓存一开始有4个对象,但是经过迭代获取后,二级缓存有8个对象?