真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯網站制作重慶分公司

(20)Hibernate二級緩存

1、二級緩存的知識

創(chuàng)新互聯主營津南網站建設的網絡公司,主營網站建設方案,app開發(fā)定制,津南h5重慶小程序開發(fā)搭建,津南網站營銷推廣歡迎津南等地區(qū)企業(yè)咨詢

Hibernate提供的緩存:有一級緩存、二級緩存。 目的是為了減少對數據庫的訪問次數,提升程序執(zhí)行效率!

一級緩存:基于Session的緩存,緩存內容只在當前session有效,session關閉,緩存內容失效!

特點:作用范圍較??! 緩存的時間短。緩存效果不明顯。

二級緩存

Hibernate提供了基于應用程序級別的緩存, 可以跨多個session,即不同的session都可以訪問緩存數據。 這個緩存也叫二級緩存。

Hibernate提供的二級緩存有默認的實現,且是一種可插配的緩存框架!如果用戶想用二級緩存,只需要在hibernate.cfg.xml中配置即可;不想用,直接移除,不影響代碼。

如果用戶覺得hibernate提供的框架不好用,可以換其他的緩存框架或自己實現緩存框架都可以。

下面的配置位于%hibernate%/project/etc/hibernate.properties中

##########################
### Second-level Cache ###
##########################

## disable the second-level cache 二級緩存默認不開啟,需要手動開啟
#hibernate.cache.use_second_level_cache false

## enable the query cache
#hibernate.cache.use_query_cache true 開啟查詢緩存

## choose a cache implementation 二級緩存框架的實現
#hibernate.cache.provider_class org.hibernate.cache.EhCacheProvider
#hibernate.cache.provider_class org.hibernate.cache.EmptyCacheProvider
hibernate.cache.provider_class org.hibernate.cache.HashtableCacheProvider
#hibernate.cache.provider_class org.hibernate.cache.TreeCacheProvider
#hibernate.cache.provider_class org.hibernate.cache.OSCacheProvider
#hibernate.cache.provider_class org.hibernate.cache.SwarmCacheProvider

緩存的并發(fā)策略

     放入二級緩存的對象,只讀; 
  非嚴格的讀寫
    讀寫; 放入二級緩存的對象可以讀、寫;
   (基于事務的策略)

2、使用二級緩存

二級緩存,使用步驟

    1)開啟二級緩存

true

    2)指定緩存框架

org.hibernate.cache.HashtableCacheProvider

    3)指定那些類加入二級緩存





    4)測試二級緩存!

示例代碼和配置

hibernate.cfg.xml




    
    
        
        com.MySQL.jdbc.Driver
        jdbc:mysql:///test	
        root
        root
		
        org.hibernate.dialect.MySQL5Dialect
        
        
		
		true
		
		false
		
		update
		

		
		
		true
		
		org.hibernate.cache.HashtableCacheProvider
		
		true
		
		
		
		
		
		
    

Department.java

package com.rk.hibernate.cache;

import java.util.Set;

public class Department
{
	private int deptId;
	private String deptName;
	private Set emps;
	private int version;
	
	public int getVersion()
	{
		return version;
	}
	public void setVersion(int version)
	{
		this.version = version;
	}
	public int getDeptId()
	{
		return deptId;
	}
	public void setDeptId(int deptId)
	{
		this.deptId = deptId;
	}
	public String getDeptName()
	{
		return deptName;
	}
	public void setDeptName(String deptName)
	{
		this.deptName = deptName;
	}
	public Set getEmps()
	{
		return emps;
	}
	public void setEmps(Set emps)
	{
		this.emps = emps;
	}
	@Override
	public String toString()
	{
		return "Department [deptId=" + deptId + ", deptName=" + deptName + "]";
	}
	
}

Department.hbm.xml




	
		
		
			
		
		
		
		
			
			
			
		
	


	

Employee.java

package com.rk.hibernate.cache;

public class Employee
{
	private int empId;
	private String empName;
	private int salary;
	private Department dept;
	private int version;
	
	public int getVersion()
	{
		return version;
	}
	public void setVersion(int version)
	{
		this.version = version;
	}
	public int getEmpId()
	{
		return empId;
	}
	public void setEmpId(int empId)
	{
		this.empId = empId;
	}
	public String getEmpName()
	{
		return empName;
	}
	public void setEmpName(String empName)
	{
		this.empName = empName;
	}
	public int getSalary()
	{
		return salary;
	}
	public void setSalary(int salary)
	{
		this.salary = salary;
	}
	public Department getDept()
	{
		return dept;
	}
	public void setDept(Department dept)
	{
		this.dept = dept;
	}
	@Override
	public String toString()
	{
		return "Employee [empId=" + empId + ", empName=" + empName + ", salary=" + salary + "]";
	}
	
}

Employee.hbm.xml




	
		
		
			
		
		
		
		
		
	

App.java

package com.rk.hibernate.cache;

import java.util.Iterator;
import java.util.List;
import java.util.Set;

import org.hibernate.Query;
import org.hibernate.SQLQuery;
import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.cfg.Configuration;
import org.junit.Test;


public class App
{
	private static SessionFactory sf;
	static
	{
		sf = new Configuration()
						.configure()
						.addClass(Department.class)
						.addClass(Employee.class)
						.buildSessionFactory();
	}
	
	
	// 1. 測試二級緩存的使用
	//思路:sesion本身提供了一級緩存,它是mandatory,不能關閉
	//二級緩存,是optional,通過配置文件可以開啟,可以關閉。
	//如果不開啟二級緩存,兩個session查詢同一個id的數據,會發(fā)送兩個SQL語句
	//如果開啟二級緩存,兩個session查詢同一個id的數據,會發(fā)送一條SQL語句
	//通過開啟和關閉二級緩存,來查看執(zhí)行的SQL數目
	@Test
	public void testSecondLevelCache()
	{
		//第1次查詢,第一個session
		Session session1 = sf.openSession();
		session1.beginTransaction();		
		Department dept1 = (Department) session1.get(Department.class, 3);
		Set emps1 = dept1.getEmps();
		System.out.println(dept1);
		System.out.println(emps1);
		session1.getTransaction().commit();
		session1.close();
		
		System.out.println("-------------------------------");
		
		//第2次查詢,第二個session
		Session session2 = sf.openSession();
		session2.beginTransaction();		
		Department dept2 = (Department) session2.get(Department.class, 3);
		Set emps2 = dept2.getEmps();
		System.out.println(dept2);		
		System.out.println(emps2);
		session2.getTransaction().commit();
		session2.close();
	}
	
	
	@Test
	public void testQueryCache()
	{
		// 第1次查詢,第一個session
		Session session1 = sf.openSession();
		session1.beginTransaction();
		// HQL查詢  【setCacheable  指定從二級緩存找,或者是放入二級緩存】
		Query q1 = session1.createQuery("from Department").setCacheable(true);
		List list1 = q1.list();
		System.out.println(list1);
		session1.getTransaction().commit();
		session1.close();

		System.out.println("-------------------------------");

		// 第2次查詢,第二個session
		Session session2 = sf.openSession();
		session2.beginTransaction();
		// HQL查詢  【setCacheable  指定從二級緩存找,或者是放入二級緩存】
		Query q2 = session2.createQuery("from Department").setCacheable(true);
		List list2 = q2.list();
		System.out.println(list2);
		session2.getTransaction().commit();
		session2.close();
	}
	
}

當我們開啟二級緩存后,例如在上面的testSecondLevelCache()方法中,第一次從Session讀取數據后,會存儲在二級緩存上;第二次打開Session,程序再進行相同查詢,就不需要再發(fā)送SQL語句,因為它會從二級緩存中讀取數據。

有一點需要注意如果二級緩存中沒有數據,第一次開啟Session讀取數據,并調用session.clear()方法,再讀取數據,會發(fā)送兩次SQL語句。

	@Test
	public void test1()
	{
		// 第1次查詢,第一個session
		Session session1 = sf.openSession();
		session1.beginTransaction();
		Department dept1 = (Department) session1.get(Department.class, 2);
		System.out.println(dept1);	
		System.out.println(dept1.getEmps());
		
		session1.clear();
		dept1 = (Department) session1.get(Department.class, 2);
		System.out.println(dept1);	
		System.out.println(dept1.getEmps());
		
		session1.getTransaction().commit();
		session1.close();

	}

結果如下:

Hibernate: select department0_.id as id0_0_, department0_.dept_version as dept2_0_0_, department0_.name as name0_0_ from T_Department department0_ where department0_.id=?
Department [deptId=2, deptName=woqu]
Hibernate: select emps0_.deptId as deptId0_1_, emps0_.id as id1_, emps0_.id as id1_0_, emps0_.emp_version as emp2_1_0_, emps0_.name as name1_0_, emps0_.salary as salary1_0_, emps0_.deptId as deptId1_0_ from T_Employee emps0_ where emps0_.deptId=?
[Employee [empId=3, empName=TO_T_, salary=4]]
Hibernate: select department0_.id as id0_0_, department0_.dept_version as dept2_0_0_, department0_.name as name0_0_ from T_Department department0_ where department0_.id=?
Department [deptId=2, deptName=woqu]
Hibernate: select emps0_.deptId as deptId0_1_, emps0_.id as id1_, emps0_.id as id1_0_, emps0_.emp_version as emp2_1_0_, emps0_.name as name1_0_, emps0_.salary as salary1_0_, emps0_.deptId as deptId1_0_ from T_Employee emps0_ where emps0_.deptId=?
[Employee [empId=3, empName=TO_T_, salary=4]]

如果二級緩存中已經存在數據,第二次開啟Session,調用session.clear(),再讀取數據,并不會發(fā)送SQL語句。

	@Test
	public void test1()
	{
		Session session2 = sf.openSession();
		session2.beginTransaction();
		Department dept2 = (Department) session2.get(Department.class, 2);
		System.out.println(dept2);	
		System.out.println(dept2.getEmps());
		
		session2.getTransaction().commit();
		session2.close();
		
		System.out.println("-------------------------------");
		
		
		// 第1次查詢,第一個session
		Session session1 = sf.openSession();
		session1.beginTransaction();
		Department dept1 = (Department) session1.get(Department.class, 2);
		System.out.println(dept1);	
		System.out.println(dept1.getEmps());
		
		session1.clear();
		dept1 = (Department) session1.get(Department.class, 2);
		System.out.println(dept1);	
		System.out.println(dept1.getEmps());
		
		session1.getTransaction().commit();
		session1.close();

		System.out.println("-------------------------------");
	}

結果如下:

Hibernate: select department0_.id as id0_0_, department0_.dept_version as dept2_0_0_, department0_.name as name0_0_ from T_Department department0_ where department0_.id=?
Department [deptId=2, deptName=woqu]
Hibernate: select emps0_.deptId as deptId0_1_, emps0_.id as id1_, emps0_.id as id1_0_, emps0_.emp_version as emp2_1_0_, emps0_.name as name1_0_, emps0_.salary as salary1_0_, emps0_.deptId as deptId1_0_ from T_Employee emps0_ where emps0_.deptId=?
[Employee [empId=3, empName=TO_T_, salary=4]]
-------------------------------
Department [deptId=2, deptName=woqu]
[Employee [empId=3, empName=TO_T_, salary=4]]
Department [deptId=2, deptName=woqu]
[Employee [empId=3, empName=TO_T_, salary=4]]
-------------------------------


網站標題:(20)Hibernate二級緩存
URL鏈接:http://weahome.cn/article/pcsohg.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部