1. get/load区别
如果记录存在,get返回对象(或代理对象);否则返回null。
如果记录存在,load返回对象;否则返回 NotObjectFoundException
2.hibernate Cache
2.1 一级缓存,在当前session内
2.2 Query Cache
Cache queries and results.
方法:
1. 在hiberante Configuration 文件中:
<property name="hibernate.cache.use_query_cache">true</property>
2. 查询时
Query query = session.createQuery("from Person p where p.id=1");
query.setCacheable(true);
2.3 二级缓存, 跨session . 如EHCache
3. load 与 CreateQuery 在处理Cache的区别
首先,load时在一个session中,一级缓存总是有效的。比如下面的只issue sql操作一次
其次,如果用CreateQuery有点不同,比若下面的需要issue sql操作两次
原因是session cache时是根据key(load方法中传入的ID)来缓存的。解决的方法是:
1. 用load,如上面的代码
2. 用查询缓存,如上面的介绍
如果记录存在,get返回对象(或代理对象);否则返回null。
如果记录存在,load返回对象;否则返回 NotObjectFoundException
2.hibernate Cache
2.1 一级缓存,在当前session内
2.2 Query Cache
Cache queries and results.
方法:
1. 在hiberante Configuration 文件中:
<property name="hibernate.cache.use_query_cache">true</property>
2. 查询时
Query query = session.createQuery("from Person p where p.id=1");
query.setCacheable(true);
2.3 二级缓存, 跨session . 如EHCache
3. load 与 CreateQuery 在处理Cache的区别
首先,load时在一个session中,一级缓存总是有效的。比如下面的只issue sql操作一次
- Session session = getSessionFactory().openSession();
- Transaction tx = session.beginTransaction();
- Person person1 = (Person) session.load(Person.class, 1L);
- System.out.println(person1.getFirstName());
- Person person2 = (Person) session.load(Person.class, 1L);
- System.out.println(person2.getFirstName());
- tx.commit();
- session.close();
其次,如果用CreateQuery有点不同,比若下面的需要issue sql操作两次
- Session session = getSessionFactory().openSession();
- Transaction tx = session.beginTransaction();
- Query query = session.createQuery("from Person p where p.id=1");
- Iterator it = query.list().iterator();
- while (it.hasNext ()){
- Person p = (Person) it.next();
- System.out.println(p.getFirstName());
- }
- query = session.createQuery("from Person p where p.id=1");
- it = query.list().iterator();
- while (it.hasNext ()){
- Person p = (Person) it.next();
- System.out.println(p.getFirstName());
- }
- tx.commit();
- session.close();
原因是session cache时是根据key(load方法中传入的ID)来缓存的。解决的方法是:
1. 用load,如上面的代码
2. 用查询缓存,如上面的介绍
- Session session = getSessionFactory().openSession();
- Transaction tx = session.beginTransaction();
- Query query = session.createQuery("from Person p where p.id=1");
- query.setCacheable(true);
- Iterator it = query.list().iterator();
- while (it.hasNext ()){
- Person p = (Person) it.next();
- System.out.println(p.getFirstName());
- }
- query = session.createQuery("from Person p where p.id=1");
- query.setCacheable(true);
- it = query.list().iterator();
- while (it.hasNext ()){
- Person p = (Person) it.next();
- System.out.println(p.getFirstName());
- }
- tx.commit();
- session.close();
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· 单元测试从入门到精通
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 上周热点回顾(3.3-3.9)
· winform 绘制太阳,地球,月球 运作规律