get和load方式是根据id取得一个记录
下边详细说一下get和load的不同,因为有些时候为了对比也会把find加进来。
1.从返回结果上对比:
load方式检索不到的话会抛出org.hibernate.ObjectNotFoundException异常
get方法检索不到的话会返回null
2.从检索执行机制上对比:
get方法和find方法都是直接从数据库中检索
而load方法的执行则比较复杂
■ 首先查找session的persistent Context中是否有缓存,如果有则直接返回
■ 如果没有则判断是否是lazy,如果不是直接访问数据库检索,查到记录返回,查不到抛出异常
■ 如果是lazy则需要建立代理对象,对象的initialized属性为false,target属性为null
■ 在访问获得的代理对象的属性时,检索数据库,如果找到记录则把该记录的对象复制到代理对象的target上,并将initialized=true,如果找不到就抛出异常。
3.根本区别说明
■ 如果你使用load方法,hibernate认为该id对应的对象(数据库记录)在数据库中是一定存在的,所以它可以放心的使用,它可以放心的使用代理来延迟加载该对象。在用到对象中的其他属性数据时才查询数据库,但是万一数据库中不存在该记录,那没办法,只能抛异常。所说的load方法抛异常是指在使用该对象的数据时,数据库中不存在该数据时抛异常,而不是在创建这个对象时(注意:这就是由于“延迟加载”在作怪)。
由于session中的缓存对于hibernate来说是个相当廉价的资源,所以在load时会先查一下session缓存看看该id对应的对象是否存在,不存在则创建代理。所以如果你知道该id在数据库中一定有对应记录存在就可以使用load方法来实现延迟加载。
■ 对于get方法,hibernate会确认一下该id对应的数据是否存在,首先在session缓存中查找,然后在二级缓存中查找,还没有就查数据库,数据库中没有就返回null。
对于load和get方法返回类型:虽然好多书中都这么说:“get()永远只返回实体类”,但实际上这是不正确的,get方法如果在 session缓存中找到了该id对应的对象,如果刚好该对象前面是被代理过的,如被load方法使用过,或者被其他关联对象延迟加载过,那么返回的还是原先的代理对象,而不是实体类对象,如果该代理对象还没有加载实体数据(就是id以外的其他属性数据),那么它会查询二级缓存或者数据库来加载数据,但是返回的还是代理对象,只不过已经加载了实体数据。
get方法首先查询session缓存,没有的话查询二级缓存,最后查询数据库;反而load方法创建时首先查询session缓存,没有就创建代理,实际使用数据时才查询二级缓存和数据库。
4.简单总结
总之对于get和load的根本区别,一句话,hibernate对于load方法认为该数据在数据库中一定存在,可以放心的使用代理来延迟加载,如果在使用过程中发现了问题,只能抛异常;而对于get方法,hibernate一定要获取到真实的数据,否则返回null。
相关推荐
在Java的持久化框架Hibernate中,`get`和`load`方法都是用于从数据库中获取对象,但它们之间存在一些重要的区别。理解这些差异对于优化应用程序的性能和避免潜在问题至关重要。 首先,让我们来深入了解一下`get`...
- `get`方法和`find`方法的行为相似,它们都会直接从数据库中检索数据。 - `load`方法的执行则更为复杂,它首先检查Session的持久化上下文(persistent Context)中是否存在缓存,如果有则直接返回。如果不存在且...
- 加载和检索:find()、get()、load()等方法用于根据主键获取对象。 6. **查询** - HQL(Hibernate Query Language):面向对象的查询语言,类似于SQL,但更贴近于Java对象。 - Criteria API:提供更加面向对象...
8. **对象获取方法**:`get()`、`load()`和`find()`用于获取指定ID的对象。`get()`和`load()`首先查找缓存,`find()`始终查询数据库。`get()`和`load()`效率相对较高,但`load()`不立即执行SQL,可能导致延迟加载...
**临时状态(Transient) -> 持久化状态(Persistent)**:通过调用Session的`get()`, `load()`, `find()`, `iterate()`等方法,可以直接将新创建的对象绑定到数据库中的记录,从而使其进入持久化状态。 **游离状态...
`get` 和 `load`: 这两个方法都是用于从数据库中获取单个对象。`get`方法直接返回一个实体对象,如果数据库中没有找到对应ID的数据,则返回null。而`load`方法返回的是一个代理对象,即使数据库中没有对应的记录,...
- 编写业务逻辑:调用HibernateTemplate提供的方法,如`save()`, `update()`, `delete()`, `get()`, `load()`, `execute()`等,进行数据库操作。 6. **优点与局限性**: HibernateTemplate简化了代码,提供了事务...
Session的多种方法如`save()`, `load()`, `get()`, `find()`, `update()`, `saveOrUpdate()`, `lock()`等可以将对象转变为持久化状态。 3. **离线对象(Detached Objects)**: - 离线对象是曾经是持久化对象,但...
5. **对象的检索(Find)**: 使用Session的get()方法或createQuery()执行HQL查询,可以获取数据库中的对象。 6. **对象的级联操作(Cascading)**: 通过设置 Cascade 属性,可以将操作(如保存、更新、删除)自动...
本文详细介绍了 Hibernate 提供的各种查询方式,包括 `load`、`get`、`createQuery` 和 `find` 等方法,并重点阐述了 HQL 查询的基本用法和高级技巧。通过本文的学习,读者可以掌握 Hibernate 的基本查询操作,并能...
注意,如果在不同Session中更新对象,你需要先调用`session.load()`或`session.get()`来重新获取对象,因为Session之间的对象是隔离的。此外,如果对象在Session之外被更新,那么在更新之前需要调用`session.update...
- get()和load():根据主键获取对象,load()会延迟加载。 - find():通过HQL或Criteria API执行查询。 5. Hibernate缓存机制: - 第一级缓存:SessionFactory级别的,每个Session都有自己的缓存,存储当前...
3. 加载与检索:`get()`和`load()`用于根据ID加载对象,`find()`和`list()`支持基于HQL或Criteria的查询。 五、缓存机制 Hibernate提供了一级缓存(Session级别)和二级缓存(SessionFactory级别),有效减少了...
6. **实体转换**:将数据库查询结果转化为对应的Java对象,通常是通过`Session.load()`或`Session.get()`方法,或者通过`Query.list()`获取集合后再进行转换。 7. **异常处理**:封装Hibernate和JDBC抛出的异常,...
5. **查询和结果集处理**:提供了丰富的查询方法,如`find()`, `load()`, `get()`等,以及方便的结果集转换和分页功能。 6. **Callback机制**:通过HibernateCallback接口,可以在Hibernate Session内部执行自定义...
1. **仅限特定方法:**延迟加载仅适用于`load`, `get`, `find`等方法,不适用于HQL等直接编写SQL的方式。 2. **调试考虑:**在调试时,如果使用了延迟加载,要注意查看代理对象的实际类型,以确保正确理解其行为。 3...
3. **Session接口**:作为与数据库交互的主要接口,Session包含了增删改查(CRUD)的基本操作,如save()、update()、delete()、get()、load()、find()等,以及事务管理相关的方法。 4. **Query和Criteria查询**:...
2. 读取(Read):`get()`和`load()`用于根据主键获取对象,`find()`和`query()`则支持更复杂的查询。 3. 更新(Update):`update()`方法更新已存在的对象。 4. 删除(Delete):`delete()`方法删除对象。 七、HQL...
4. 加载和检索:get()和load()加载单个对象,find()和query()用于执行HQL或Criteria查询。 六、级联操作 通过设置属性 cascade,可以控制实体间的操作是否级联,例如级联保存、更新、删除等。 七、缓存机制 ...
`find()`方法可以进行简单的SQL查询,而`createQuery()`和`createSQLQuery()`则支持更复杂的HQL(Hibernate Query Language)和原生SQL查询。 7. **事务管理**:在执行增删改查操作时,通常需要包裹在事务中以确保...