MyBatis的分布查询延迟加载(select_resultMap)

MyBatis的分布查询延迟加载(select_resultMap)

	<!-- 分布好处  可以使用延迟加载  	     Employee==>Dept  	          我们每次查询Employee对象的时候,都将一起查询出来。  	          部门信息在我们使用的时候再去查询  	          分段查询的基础之上加上两个配置  	 -->


mybatis-config.xml  改变配置文件

	<settings> 		<setting name="mapUnderscoreToCamelCase" value="true" />  //驼峰命名法 		<!-- 懒加载 ,延迟加载--> 		<setting name="lazyLoadingEnabled" value="true"/>  		<!-- 立即加载 --> 		<setting name="aggressiveLazyLoading" value="false"/> 	</settings>

测试方法

@Test 	public void test05() throws IOException{ 		SqlSessionFactory sqlsessionFactory=getSqlSessionFactory(); 		// 1  获取到的sqlsession不会自动提交数据 		SqlSession openSession=sqlsessionFactory.openSession();  		try{  			EmployeeMapperPlus mapper=openSession.getMapper(EmployeeMapperPlus.class); 			//级联查询  			/*	Employee empAndDept=mapper.getEmpAndDept(1);             System.out.println(empAndDept.getLastName());*/ 			//System.out.println(empAndDept.getDept()); 			// 分布查询 			Employee  employee=mapper.getEmpByIdStep(1); 			System.out.println(employee.getLastName()); 			//System.out.println(employee.getDept());  		}finally{ 			openSession.commit(); 		} 	}

在开启延迟加载的情况下

<setting name="lazyLoadingEnabled" value="true"/> 


在没有开启延迟加载的情况,立即加载

<setting name="aggressiveLazyLoading" value="false"/>


所以好处就是

<!-- 分布好处  可以使用延迟加载  	     Employee==>Dept  	          我们每次查询Employee对象的时候,都将一起查询出来。  	          部门信息在我们使用的时候再去查询  	          分段查询的基础之上加上两个配置  	 -->

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值