hibernate5二级缓存配置

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

大家好,又见面了,我是你们的朋友全栈君。

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

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

<?xml version="1.0" encoding="utf-8" ?>
<ehcache>
    <diskStore path="java.io.tmpdir"/>
    <defaultCache 
      maxElementsInMemory="10000"
      eternal="false"
      timeToIdleSeconds="120"
      timeToLiveSeconds="120"
      overflowToDisk="true" 
     />
</ehcache>

实体类如下:

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

<?xml version="1.0" encoding="utf-8" ?>
<!DOCTYPE hibernate-configuration PUBLIC "-//Hibernate/Hibernate Configuration DTD 3.0//EN" 
"http://www.hibernate.org/dtd/hibernate-configuration-3.0.dtd" >
<hibernate-configuration>
   <session-factory>
        <property name="connection.driver_class">com.mysql.jdbc.Driver</property>
        <property name="connection.url">jdbc:mysql:///hibernate?useUnicode=true&amp;characterEncoding=utf-8&amp;useSSL=false</property>
        <property name="connection.username">root</property>
        <property name="connection.password">root</property>
        <property name="connection.pool_size">20</property>
        <property name="dialect">org.hibernate.dialect.MySQL57InnoDBDialect</property>
        <property name="show_sql">true</property>
        <property name="format_sql">true</property>
        <property name="hbm2ddl.auto">update</property>
        <property name="hibernate.cache.use_second_level_cache">true</property>
        <property name="hibernate.cache.provider_class">org.hibernate.cache.EhCacheProvider</property>
        <property name="hibernate.cache.region.factory_class">org.hibernate.cache.ehcache.EhCacheRegionFactory</property>
        <property name="hibernate.cache.use_query_cache">true</property>
        <mapping class="com.xxx.hibernate.domain.User"/>
   </session-factory>
</hibernate-configuration>

 测试类代码:

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> session = new ThreadLocal<Session>();
	
	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<User> 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()方法,打印关键信息如下:

hibernate5二级缓存配置

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

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/142508.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • Spring batch教程 之 配置Step「建议收藏」

    Spring batch教程 之 配置Step「建议收藏」正如在BatchDomainLanguage中叙述的,Step是一个独立封装域对象,包含了所有定义和控制实际处理信息批任务的序列。这是一个比较抽象的描述,因为任意一个Step的内容都是开发者自己编写的Job。一个Step的简单或复杂取决于开发者的意愿。一个简单的Step也许是从本地文件读取数据存入数据库,写很少或基本无需写代码。一个复杂的Step也许有复杂的业务规则(取决于所实现的方式),并作

    2022年5月28日
    32
  • PCR雷达传感器感应_倒车雷达传感器在哪里

    PCR雷达传感器感应_倒车雷达传感器在哪里一.设备唤醒i》检测人靠近设备ii》无视穿越的人员iii》可做手势识别应用场景:智能音箱;笔记本;广告机;投影仪;灯具;控制面板开关独特算法:1》 检测静止不动的人员,内置检测人的呼吸信号。图示为雷达传感器抓取人呼吸的信号在0.3-0.35hz效果。2》 可过滤快速移动物体干扰,内置仅对慢速移动检测,图示效果为雷达传感器过滤风扇对测试的影响。二.车内人员检测欧洲新车评估计划(EuroNCAP)计划在2022年将儿童存在检测纳入全面评级。测试评估分析:1岁婴儿睡在儿童保护座椅上

    2022年9月29日
    1
  • JAVA学习Swing章节流布局管理器简单学习

    JAVA学习Swing章节流布局管理器简单学习

    2021年9月16日
    55
  • Servlet再度学习

    Servlet再度学习

    2020年11月12日
    170
  • 数据库建表语句的使用及简单实战教程_SQL数据库建立一个表

    数据库建表语句的使用及简单实战教程_SQL数据库建立一个表目录介绍需求思路思路1:一张表来表示所有数据(如下图)思路2:两张表,学生表和班级表(如下图)代码扩展1.数据库设计三范式1.数据库表中不能出现重复记录,每个字段是原子性的不能再分(不可重复,不可再分)2.第二范式是建立在第一范式基础上的,另外要求所有非主键字段完全依赖主键,不能产生部分依赖3.建立在第二范式基础上的,非主键字段不能传递依赖于主键字段。(不要产生传递依赖)2.经典的数据库设计框架–er图介绍本文将用一个简单的tip来简单介绍建表语句,可以作为建表语句的模板使用需求采集一个学校中学生

    2022年9月8日
    1
  • javascript下拉菜单代码(用jquery做下拉菜单)

    一、js实现下拉菜单二、解题思路:三、代码:1.html<ulid=”divBox”><liclass=”myLi”onclick=”openS(this,0)”><spanclass=”iconfonticon-maobifront”></span><spanclass=”font”>Diseno

    2022年4月18日
    48

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号