MyBatis实现延时加载的方式有两种:
- 使用resultMap的association和collection标签配置延时加载:在查询语句中,使用association标签配置一对一关联关系,使用collection标签配置一对多关联关系。然后在查询结果映射的resultMap中配置延时加载属性,设置fetchType为lazy。当需要加载关联数据时,MyBatis会发送额外的查询语句来加载关联数据。
例如,假设有一个User实体类和一个Order实体类,一个User可以有多个Order。在User的resultMap中配置延时加载关联的Order:
<resultMap id="userResultMap" type="User">
<id property="id" column="id" />
<result property="username" column="username" />
<association property="orders" column="id" javaType="List" select="findOrdersByUserId" fetchType="lazy" />
</resultMap>
- 使用MyBatis的二级缓存实现延时加载:MyBatis的二级缓存可以缓存查询结果,当再次查询相同的数据时,直接从缓存中获取,而不需要再次查询数据库。通过配置二级缓存,并设置延时加载属性,可以实现延时加载的效果。
<settings>
<setting name="cacheEnabled" value="true" />
<setting name="lazyLoadingEnabled" value="true" />
</settings>
以上是两种常用的方式实现延时加载,具体的实现方式可以根据具体的需求和场景选择。