当我们查询数据的时候,首先在一级缓存中去取数据,如果有,则不去数据库中取数据,否则,到数据库中去取数据
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
结果:
在数据库中查询到了
在缓存中查询到了
在缓存中查询到了
在缓存中查询到了
========================
在数据库中查询到了
在缓存中查询到了
在缓存中查询到了
在缓存中查询到了
在缓存中查询到了
========================
在数据库中查询到了
在缓存中查询到了
以上表明在第一查询的时候是在数据库中查询的数据,之后就是在缓存中获取的了