Hibernate中get查询方法和load查询方法的区别

1、使用get方法执行查询语句:

如下图所示:

执行完get方法后,执行发送了sql语句,person对象也有了值。此时,在session关闭后,person对象依然存在,因此控制台可以打印出name的值。

2、在执行load方法时:

如下图所示:

在执行完load方法后,并未向数据库发送查询语句,此时person对象的值是一个CBLIB代理对象,这个代理对象只保存了实体对象的ID的值:

此时,如果继续执行下去,关闭session后,再次执行person.getName()方法,将出现延迟加载异常:

如果在关闭session之前,执行person.getName()方法,程序将正常执行,正常发送查询请求,并打印出name的值。

调用getName()方法在关闭session之前和之后所得到的结果截然不同。这是因为在load方法查询数据,只有当我们真正使用这个对象时,才会发送sql请求,从数据库中查询出我们所需要的数据。如果关闭了session,无法向数据库发送请求,就会出现异常。

3、如果我们只打印person对象的id值时,此时控制台会打印出该id值,但是同样不会发送sql语句到数据库,这也印证了我们刚才说的person对象仅仅是保存了id的代理对象。但是如果我们需要使用person对象的其他属性时,就会向数据库发送sql请求。

 

但是,使用load方法的加载方式会比get方法的加载方式性能要好一些,因为load方法,得到的代理对象,只有在真正使用这个对象时,才会向数据库发送请求。如果不使用,就节省了向数据库查询的步骤,间接提升了系统性能。

除了以上区别,在查询id不存在的数据时,这两种方法返回的结果类型也不相同:

当我们使用get方法查询一个id不存在数据时,会返回一个null。此时如果使用对象的get方法,将会报空指针异常;

但我们使用load方法查询一个id不存在的数据时,如果不使用该对象,是不会保存的,因为load方法不会去发送sql语句到数据库,但是如果使用 对象的get方法,获取属性值时,会出现ObjectNotFoundException异常,找不到该对象。

为什么使用load的方式和get的方式来得到一个不存在的对象报的异常不同呢??其原因还是因为load的延迟加载机制,使用load时,此时的person对象是一个代理对象,仅仅保存了当前的这个id值,当我们试图得到该对象的name属性时,这个属性其实是不存在的,所以就会报出ObjectNotFoundException这个异常了。

以上就是两种方法的不同之处。

 

 

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值