1. 首先,Hibernate中维持了两级缓存。
第一级:由session实例维护,其中保持了session当前所有关联实体的数据,也成为内部缓存。
第二级:由当前所有本SessionFactory构造的Session实例共享。
Session在调用数据库查询功能之前,会先在缓存中进行查询。首先在第一级缓存中,通过实体类型和id进行查找,
如果第一级缓存查找命中,且数据状态合法,则直接返回。
2. 之后,Session会在当前“NonExists”记录中进行查找,如果“NonExists”记录中存在同样的查询条件,则返回null。
“NonExists”记录了当前Session实例在之前所有查询操作中,未能查询到有效数据的查询条件(相当于查询黑名单)。
3. 对于load方法而言,如果内部缓存中未发现有效数据,则查询第二级缓存,如果第二级缓存命中,则返回。
4. 如果在缓存中未发现有效数据,则发起数据库查询操作,如果经过查询未发现对应记录,则将此次查询的信息在“NonExists”中加以记录,并返回null。
5. 根据映射配置和Select SQL得到的ResultSet,创建对应数据对象。
6. 将其数据对象纳入当前Session实体管理容器(一级缓存)。
7. 执行Interceptor.onLoad方法(如果有对应的Interceptor)。
8. 将数据对象纳入二级缓存。
9. 如果数据对象实现了LifeCycle接口,则调用数据对象的onLoad方法。
10. 返回数据对象。
选自 深入浅出 Hibernate 【电子工业出版社】