二级缓存失效_hibernate5二级缓存配置

hibernate默认有一个一级缓存,就是默认的Session缓存,当我们做了一次查询,hibernate会把这个结果缓存起来,叫做一级缓存,当我们接着在这个Session会话里面再做一次同样条件的查询,hibernate不会再次查询数据库,而是直接在一级缓存中获取结果并返回。一级缓存是内置的,他也不能被卸载。一级缓存是指在同一个Session会话内的查询做的缓存,如果跨了Session,或者当前Session关闭,重新开启了一个新的Session,这时候一级缓存是失效的。

二级缓存是一个可插拔的缓存,可有可无,如果你配置了,他就有,没有配置就没有。二级缓存的实现,默认是用ehcache,需要增加一个配置文件ehcache.xml,如下所示:

maxElementsInMemory="10000"

eternal="false"

timeToIdleSeconds="120"

timeToLiveSeconds="120"

overflowToDisk="true"

/>

实体类如下:

BaseEntity.java

package com.xxx.hibernate.domain;

import java.util.Date;

import javax.persistence.Column;

import javax.persistence.GeneratedValue;

import javax.persistence.GenerationType;

import javax.persistence.Id;

import javax.persistence.MappedSuperclass;

@MappedSuperclass

public class BaseEntity {

@Id

@GeneratedValue(strategy=GenerationType.IDENTITY)

protected Integer id;

@Column(name="modifydate")

protected Date modifyDate;

@Column(name="createdate")

protected Date createDate;

public Integer getId() {

return id;

}

public void setId(Integer id) {

this.id = id;

}

public Date getModifyDate() {

return modifyDate;

}

public void setModifyDate(Date modifyDate) {

this.modifyDate = modifyDate;

}

public Date getCreateDate() {

return createDate;

}

public void setCreateDate(Date createDate) {

this.createDate = createDate;

}

}

User.java

package com.xxx.hibernate.domain;

import javax.persistence.Entity;

import javax.persistence.Table;

import org.hibernate.annotations.Cache;

import org.hibernate.annotations.CacheConcurrencyStrategy;

@Table(name="xx_user")

@Entity

@Cache(usage=CacheConcurrencyStrategy.READ_WRITE)

public class User extends BaseEntity{

private String name;

private int age;

private String email;

private String mobile;

private String password;

public String getName() {

return name;

}

public void setName(String name) {

this.name = name;

}

public int getAge() {

return age;

}

public void setAge(int age) {

this.age = age;

}

public String getEmail() {

return email;

}

public void setEmail(String email) {

this.email = email;

}

public String getMobile() {

return mobile;

}

public void setMobile(String mobile) {

this.mobile = mobile;

}

public String getPassword() {

return password;

}

public void setPassword(String password) {

this.password = password;

}

@Override

public String toString() {

return "user:[id="+id+",name="+name+",age="+age+

",email="+email+",mobile="+mobile+"]";

}

}

hibernate.cfg.xml

/p>

"http://www.hibernate.org/dtd/hibernate-configuration-3.0.dtd" >

com.mysql.jdbc.Driver

jdbc:mysql:///hibernate?useUnicode=true&characterEncoding=utf-8&useSSL=false

root

root

20

org.hibernate.dialect.MySQL57InnoDBDialect

true

true

update

true

org.hibernate.cache.EhCacheProvider

org.hibernate.cache.ehcache.EhCacheRegionFactory

true

测试类代码:

package com.xxx.hibernate.test;

import java.util.Date;

import java.util.List;

import org.hibernate.Session;

import org.hibernate.SessionFactory;

import org.hibernate.Transaction;

import org.hibernate.cfg.Configuration;

import com.xxx.hibernate.domain.User;

public class HibernateAppTest {

private static SessionFactory sessionFactory;

private static final ThreadLocal session = new ThreadLocal();

static{

try {

Configuration cfg = new Configuration().configure();

sessionFactory = cfg.buildSessionFactory();

} catch (Exception e) {

e.printStackTrace();

}

}

public static Session getSession(){

Session sess = session.get();

if(sess==null){

sess = sessionFactory.openSession();

session.set(sess);

}

return sess;

}

public static void closeSession(){

Session sess = session.get();

if(sess!=null){

sess.close();

}

session.set(null);

sessionFactory.close();

}

public static void add(String name,int age,String email,String mobile,String password){

User user = new User();

user.setName(name);

user.setAge(age);

user.setEmail(email);

user.setMobile(mobile);

user.setPassword(password);

user.setCreateDate(new Date());

user.setModifyDate(new Date());

//

Session sess = getSession();

Transaction tx = sess.beginTransaction();

sess.save(user);

tx.commit();

closeSession();

}

public static void search(Integer id){

Session sess = getSession();

User user = sess.get(User.class, id);

if(user!=null)

System.out.println(user);

}

public static void testDefaultCache(){

long start = System.currentTimeMillis();

search(2);

long end = System.currentTimeMillis();

System.out.println("it takes "+(end-start)+" .");

//======================

start = System.currentTimeMillis();

search(2);

end = System.currentTimeMillis();

System.out.println("it takes "+(end-start)+" .");

start = System.currentTimeMillis();

search(1);

end = System.currentTimeMillis();

System.out.println("it takes "+(end-start)+" .");

closeSession();

}

@SuppressWarnings("unchecked")

public static void testL2Cache(){

Session sess = sessionFactory.openSession();

List list = sess.createQuery("from User").setCacheable(true).list();

for(User user:list){

System.out.println(user);

}

sess.close();

System.out.println("=======================分割线======================");

Session sess2 = sessionFactory.openSession();

list = sess2.createQuery("from User").setCacheable(true).list();

for(User user:list){

System.out.println(user);

}

sess2.close();

closeSession();

}

public static void main(String[] args) {

//add("xxx", 18, "xxx@hibernate.cn", "15902020509", "123456");

//add("aaa", 33, "aaa@hibernate.cn", "15902020520", "123456");

//testDefaultCache();

testL2Cache();

}

}

运行testL2Cache()方法,打印关键信息如下:

第一次查询,打印了sql语句,说明从数据库中做了查询,第二次查询,直接使用了二级缓存,因此,并没有打印sql语句。这个结果说明hibernate二级缓存配置正确并且生效了。

8ef681f608da1a3dce0419588b1a04e6.png
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值