MyBatis延迟加载及在spring中集成配置

简介:  当你要使用one to one,many to one 就会碰到N+1的问题。很明显,对象之间关联很多有A关联B,B关联C,C关联A这样的关系,如果不是采用延迟加载,很容易一下在出现成千上万对象,造成N+1的问题。   而Mybatis 设置延迟加载主要2个属性配置: <?xml version="1.0" encoding="UTF-8"?> 


当你要使用one to one,many to one 就会碰到N+1的问题。很明显,对象之间关联很多有A关联B,B关联C,C关联A这样的关系,如果不是采用延迟加载,很容易一下在出现成千上万对象,造成N+1的问题。

 

而Mybatis 设置延迟加载主要2个属性配置:


  1. <?xml version="1.0" encoding="UTF-8"?>    
  2. <!DOCTYPE configuration     
  3.   PUBLIC "-//ibatis.apache.org//DTD Config 3.0//EN" "http://ibatis.apache.org/dtd/ibatis-3-config.dtd">    
  4.     
  5. <configuration>  
  6.     <settings>  
  7.         <setting name="lazyLoadingEnabled" value="false"/>  
  8.         <setting name="aggressiveLazyLoading" value="true"/>  
  9.     </settings>  
  10. </configuration>     
<?xml version="1.0" encoding="UTF-8"?>  
<!DOCTYPE configuration   
  PUBLIC "-//ibatis.apache.org//DTD Config 3.0//EN" "http://ibatis.apache.org/dtd/ibatis-3-config.dtd">  
  
<configuration>
	<settings>
		<setting name="lazyLoadingEnabled" value="false"/>
		<setting name="aggressiveLazyLoading" value="true"/>
	</settings>
</configuration>   

 

lazyLoadingEnabled:true使用延迟加载,false禁用延迟加载。默认为true

 

aggressiveLazyLoading:true启用时,当延迟加载开启时访问对象中一个懒对象属性时,将完全加载这个对象的所有懒对象属性。false,当延迟加载时,按需加载对象属性(即访问对象中一个懒对象属性,不会加载对象中其他的懒对象属性)。默认为true

 

   加载所有懒对象


  1. <configuration>  
  2.     <settings>  
  3.         <setting name="lazyLoadingEnabled" value="true"/>  
  4.         <setting name="aggressiveLazyLoading" value="true"/>  
  5.     </settings>  
  6. </configuration>    
<configuration>
	<settings>
		<setting name="lazyLoadingEnabled" value="true"/>
		<setting name="aggressiveLazyLoading" value="true"/>
	</settings>
</configuration>  

 

   按需加载对象属性

<configuration>  
  1.     <settings>  
  2.         <setting name="lazyLoadingEnabled" value="true"/>  
  3.         <setting name="aggressiveLazyLoading" value="false"/>  
  4.     </settings>  
  5. </configuration>   
<configuration>
	<settings>
		<setting name="lazyLoadingEnabled" value="true"/>
		<setting name="aggressiveLazyLoading" value="false"/>
	</settings>
</configuration>  

对继承spring配置如下:

  1. <bean id="sqlSessionFactory"  
  2.     class="org.mybatis.spring.SqlSessionFactoryBean">  
  3.     <property name="configLocation" value="classpath:setting.xml"/>  
  4.     <property name="dataSource" ref="dataSource" />  
  5. </bean>  
	<bean id="sqlSessionFactory"
		class="org.mybatis.spring.SqlSessionFactoryBean">
		<property name="configLocation" value="classpath:setting.xml"/>
		<property name="dataSource" ref="dataSource" />
	</bean>

setting.xml是mybatis全局属性配置文件。

目录
相关文章
|
30天前
ssm(Spring+Spring mvc+mybatis)——updateDept.jsp
ssm(Spring+Spring mvc+mybatis)——updateDept.jsp
10 0
|
30天前
ssm(Spring+Spring mvc+mybatis)——showDept.jsp
ssm(Spring+Spring mvc+mybatis)——showDept.jsp
9 0
|
29天前
|
SQL Java 数据库连接
springboot中配置mybatis别名该怎么写?
springboot中配置mybatis别名该怎么写?
22 0
|
29天前
|
SQL Java 数据库连接
挺详细的spring+springmvc+mybatis配置整合|含源代码
挺详细的spring+springmvc+mybatis配置整合|含源代码
35 1
|
7天前
|
Java 数据库连接 数据库
MyBatis之旅:从零开始的环境搭建与配置
MyBatis之旅:从零开始的环境搭建与配置
21 1
|
23天前
|
敏捷开发 监控 前端开发
Spring+SpringMVC+Mybatis的分布式敏捷开发系统架构
Spring+SpringMVC+Mybatis的分布式敏捷开发系统架构
55 0
|
25天前
Mybatis+mysql动态分页查询数据案例——配置映射文件(HouseDaoMapper.xml)
Mybatis+mysql动态分页查询数据案例——配置映射文件(HouseDaoMapper.xml)
14 1
|
25天前
|
SQL Java 数据库连接
mybatis关联配置(一对多配置)
mybatis关联配置(一对多配置)
13 1
|
30天前
|
Java Windows Perl
mybatis+spring报错PropertyAccessException 1: org.springframework.beans.MethodInvocationException
mybatis+spring报错PropertyAccessException 1: org.springframework.beans.MethodInvocationException
8 0