Mybatis加载策略的实现方法

网友投稿 244 2022-08-25


Mybatis加载策略的实现方法

目录MaBatis加载策略1.什么是延迟加载1.2实现1.2.1局部延迟加载1.2.2设置触发延迟加载的方法1.2.3全局延迟加载

MaBatis加载策略

1.什么是延迟加载

Mybatis中一对一,一对多,多对多关系的配置及实现,可以实现对象的关联查询。实际开发过程中很多时候我们并不需要总是在加载用户信息时就一定要加载他的订单信息。此时就是我们所说的延迟加载。

例如:

问题1:在一对多中,当我们有一个用户,它有个100个订单在查询用户的时候,要不要把关联的订单查出来?

回答:在查询用户时,用户下的订单应该是,什么时候用,什么时候查询。(一对多)

**问题2:**在查询订单的时候,要不要把关联的用户查出来?

在查询订单时,订单所属的用户信息应该是随着订单一起查询出来。(多对一) 1.1延迟加载

就是在需要用到数据时才进行加载,不需要用到数据时就不加载数据。延迟加载也称懒加载。

注意:

延迟加载是基于嵌套查询来实现的

优点:

先从单表查询,需要时再从关联表去关联查询,大大提高数据库性能,因为查询单表要比关联查询多张表速度要快。

缺点:

因为只有当需要用到数据时,才会进行数据库查询,这样在大批量数据查询时,因为查询工作也要消耗时间,所以可能造成用户等待时间变长,造成用户体验下降。

在多表中:

一对多,多对多:通常情况下采用延迟加载一对一(多对一):通常情况下采用立即加载

1.2实现

1.2.1 局部延迟加载

在association和collection标签中都有一个fetchType属性,通过修改它的值,可以修改局部的加载策略。

xml配置文件:

select * from user

1.2.2 设置触发延迟加载的方法

大家在配置了延迟加载策略后,发现即使没有调用关联对象的任何方法,但是在你调用当前对象的equals、clone、hashCode、toString方法时也会触发关联对象的查询。我们可以在配置文件中使用lazyLoadTriggerMethods配置项覆盖掉上面四个方法。

1.2.3全局延迟加载

引入全局延迟加载,目的是解放局部延迟加载在标签collection中加入一直家fetchType参数。从而可以做到所有的嵌套查询是实现全局延迟加载。在Mybatis的核心配置文件中可以使用setting标签修改全局的加载策略。

注意:局部的加载策略优先级高于全局的加载策略。

订单没有被查询出来:


版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:python--内置方法eval、zip、enumerate(在python中,使用内置函数)
下一篇:python--内置方法eval、zip、enumerate(python内置函数使用方法)
相关文章

 发表评论

暂时没有评论,来抢沙发吧~