【MyBatis】延迟加载

       需求:查询订单并且关联查询用户信息。如果先查询订单信息即可满足要求,当我们需要查询用户信息时再查询用户信息。我们把对用户信息的按需查询,称作延迟加载。

       所以延迟加载的理解即:先单表查询,当需要时,在从关联表去级联查询,大大提高数据库性能。

1.mapper.xml

<!-- 延迟加载的resultMap -->
<resultMap type="cn.itcast.mybatis.po.Orders" id="OrdersUserLazyLoadingResultMap">
		<!--对订单信息进行映射配置  -->
		<id column="id" property="id"/>
		<result column="user_id" property="userId"/>
		<result column="number" property="number"/>
		<result column="createtime" property="createtime"/>
		<result column="note" property="note"/>
		<!-- 实现对用户信息进行延迟加载
		select:指定延迟加载需要执行的statement的id(是根据user_id查询用户信息的statement)
		要使用userMapper.xml中findUserById完成根据用户id(user_id)用户信息的查询,如果findUserById不在本mapper中需要前边加namespace
		column:订单信息中关联用户信息查询的列,是user_id
		关联查询的sql理解为:
		SELECT orders.*,
(SELECT username FROM USER WHERE orders.user_id = user.id)username,
(SELECT sex FROM USER WHERE orders.user_id = user.id)sex
 FROM orders
		 -->
		<association property="user"  javaType="cn.itcast.mybatis.po.User"
		 select="cn.itcast.mybatis.mapper.UserMapper.findUserById" column="user_id">
		<!-- 实现对用户信息进行延迟加载 -->
	
		</association>
		
</resultMap>

<!-- 延迟加载的Statement -->
<!-- 1.只查询订单信息 -->
<select id="findOrdersUserLazyLoading" resultMap="OrdersUserLazyLoadingResultMap">
	SELECT * FROM orders
</select>

<!-- 2.通过1中查询到的订单信息中user_id去关联查询用户信息 -->
<select id="findUserById" parameterType="int" resultType="user">
	SELECT * FROM USER WHERE id=#{value}
</select>

2.mapper.java

// 查询订单关联查询用户,用户信息是延迟加载
publicList<Orders> findOrdersUserLazyLoading() throws Exception;

3.延迟加载配置

MyBatis默认没有开启延迟加载,所以需要在SqlMapConfig.xmlsetting配置

<settings>
	<!-- 打开延迟加载 的开关 -->
	<setting name="lazyLoadingEnabled" value="true"/>
	<!-- 将积极加载改为消极加载即按需要加载 -->
	<setting name="aggressiveLazyLoading" value="false"/>	
</settings>

4.测试方法:

package cn.itcast.mybatis.mapper;

import java.io.InputStream;
import java.util.List;

import org.apache.ibatis.io.Resources;
import org.apache.ibatis.session.SqlSession;
import org.apache.ibatis.session.SqlSessionFactory;
import org.apache.ibatis.session.SqlSessionFactoryBuilder;
import org.junit.Before;
import org.junit.Test;

import cn.itcast.mybatis.po.Orders;
import cn.itcast.mybatis.po.OrdersCustom;
import cn.itcast.mybatis.po.User;

public class OrdersMapperCustomTest {
	private SqlSessionFactory sqlSessionFactory;

	@Before
	public void setUp() throws Exception {
		// 创建sqlSessionFactory

		// mybatis配置文件
		String resource = "SqlMapConfig.xml";
		// 得到配置文件流
		InputStream inputStream = Resources.getResourceAsStream(resource);

		// 创建会话工厂,传入mybatis的配置文件信息
		sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);
	}


	@Test
	public void findOrdersUserLazyLoading() throws Exception {
		SqlSession sqlSession = sqlSessionFactory.openSession();
		OrdersMapperCustom ordersMapperCustom = sqlSession
				.getMapper(OrdersMapperCustom.class);
		List<Orders> list = ordersMapperCustom.findOrdersUserLazyLoading();
		System.out.println(list);
		sqlSession.close();
	}

}

打印结果:


评论 12
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值