hibernate一级缓存(session缓存)


当我们查询数据的时候,首先在一级缓存中去取数据,如果有,则不去数据库中取数据,否则,到数据库中去取数据


1,作用

  • 提高性能,可以理解成是一个Map

2,涉及
  • 把数据存进缓存中
  • 从缓存中获取数据
  • 删除缓存中的数据
3,什么操作(一些方法)会向一级缓存中放数据
  • save       update      saveOrUpdate    load     get   list     iterate   lock
4,list 和uniqueResult不会从session缓存中取数据,而是直接去数据库中取

5,一级缓存不能控制缓存的数量,所以大批量操作数据时,可能造成内存溢出,这时我们可以用evict方法和clear方法,清除缓存中的数据
p.s: evict方法只清除一条数据,而clear方法清除所有数据

6,当session关闭后,缓存就没有了

7,用hashMap来模拟一级缓存

public class TestSessionCache {

	private static Map<Integer, User> map = new HashMap<Integer, User>();
	
	public static void main(String[] args) {
		
		getUser(1);
		getUser(1);
		getUser(1);
		getUser(1);
		System.out.println("========================");
		getUser(2);
		getUser(2);
	}
	
	/**
	 * 查询数据
	 * @param uid
	 * @return
	 */
	public static User getUser(Integer uid){
		
		if(map.containsKey(uid)){
			
			System.out.println("在缓存中查询到了");
			return map.get(uid);
		}else {
			
			System.out.println("在数据库中查询到了");
			User user = MyDB.getUserByDb(uid);
			//把查询到的数据放进session缓存中
			map.put(uid, user);
			
			return user;
		}
	}
}

class MyDB{
	
	private static List<User> listDb = new ArrayList<User>();
	
	static{
		
		User user1 = new User();
		user1.setUid(1);
		user1.setUname("coci");
		User user2 = new User();
		user2.setUid(2);
		user2.setUname("coci2");
		
		listDb.add(user1);
		listDb.add(user2);
	}
	
	/**
	 * 在数据库中查
	 * @param uid
	 * @return
	 */
	public static User getUserByDb(Integer uid){
		
		for (User user : listDb) {
			if(user.getUid()==uid){
				return user;
			}
		}
		return null;
	}
}

p.s:  注意,以上的user对象,就2个属性  uid  和  uname

结果:
在数据库中查询到了
在缓存中查询到了
在缓存中查询到了
在缓存中查询到了
========================
在数据库中查询到了
在缓存中查询到了

以上表明在第一查询的时候是在数据库中查询的数据,之后就是在缓存中获取的了

你可能感兴趣的:(hibernate一级缓存(session缓存))