简介
- 一级缓存又名Session缓存、会话级缓存
- 通过Session从数据库中查到的实体会被放到缓存中,下次查询中直接从缓存中获取
- 生命周期和Session一样
- 适用范围为当前会话中
- 缓存不可取消
常用API
- evict(实体名):将实体从Session的缓存中删除
Session session = sessionFactory.openSession();
Employee emp = session.get(Employee.class,1);
System.out.println(emp.getName());
session.evict(emp);//清除缓存中指定的emp实体对象
emp = session.get(Employee.class,1);
System.out.println(emp.getName);
会从数据库中查询两次,输出两条SQL语句
2. clear():删除缓存中的所有对象
Session session = sessionFactory.openSession();
Employee emp = session.get(Employee.class,1);
System.out.println(emp.getName());
session.clear();//清除缓存中所有的对象
emp = session.get(Employee.class,1);
System.out.println(emp.getName);
会从数据库中查询两次,输出两条SQL语句
3. List
Query query = session.createQuery("from BookEntity ");
List<BookEntity> list = query.list();
for (BookEntity bookEntity:list){
System.out.println(bookEntity);
}
select
bookentity0_.BookNO as BookNO1_0_,
bookentity0_.BookName as BookNam
e2_0_,
bookentity0_.Author as Author3_0_,
bookentity0_.Publish as Publish4_0_,
bookentity0_.BookIsbn as BookIsbn5_0_,
bookentity0_.BuyTime as BuyTime6_0_,
bookentity0_.BookPrice as BookPric7_0_,
bookentity0_.BookStatus as BookStat8_0_
from
book bookentity0_
query.list()每次查询直接从数据库中读取全部具体数据到缓存中,执行一条SQL语句
4. Iterator
Iterator<BookEntity> iterator = query.iterate();
while(iterator.hasNext()){
BookEntity bookEntity = iterator.next();
System.out.println(bookEntity);
}
select
bookentity0_.BookNO as col_0_0_
from
book bookentity0_
query.iterator()每一次查询的时候一次性从数据库中查询并返回所有数据的主键并和缓存中的实体对象的主键比较,如果比对成功,则直接从缓存中返回数据给调用者,否则,从数据库中查找主键所对应的具体数据,并将返回数据的数据给调用者并且在缓存中备份
5. List适合缓存中没有与将要查询的记录相关的实体对象,Iterator适合缓存中已经存在了与将要查询的记录相关的实体对象