【MyBatis】延迟加载
来源:互联网 发布:java大数据量并发处理 编辑:程序博客网 时间:2024/06/05 18:05
需求:查询订单并且关联查询用户信息。如果先查询订单信息即可满足要求,当我们需要查询用户信息时再查询用户信息。我们把对用户信息的按需查询,称作延迟加载。
所以延迟加载的理解即:先单表查询,当需要时,在从关联表去级联查询,大大提高数据库性能。
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中需要前边加namespacecolumn:订单信息中关联用户信息查询的列,是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.xml中setting配置
<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;@Beforepublic void setUp() throws Exception {// 创建sqlSessionFactory// mybatis配置文件String resource = "SqlMapConfig.xml";// 得到配置文件流InputStream inputStream = Resources.getResourceAsStream(resource);// 创建会话工厂,传入mybatis的配置文件信息sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);}@Testpublic 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();}}
打印结果:
1 0
- MyBatis延迟加载
- mybatis延迟加载
- MyBatis延迟加载
- Mybatis延迟加载
- MyBatis 配置延迟加载
- Mybatis 延迟加载
- mybatis延迟加载
- Mybatis的延迟加载
- MyBatis-延迟加载
- mybatis的延迟加载
- Mybatis的延迟加载
- Mybatis-延迟加载
- 【Mybatis架构】 延迟加载
- mybatis延迟加载
- mybatis--延迟加载
- 【MyBatis】延迟加载
- mybatis延迟加载
- Mybatis 延迟加载
- unity通过改变相机视野实现UI元素放大缩小的效果
- spring cloud学习(四) Fegin 的使用
- oj1946: C语言实验——单个字符输入和输出(顺序结构)
- 基于stm32f407的无线视屏传输项目
- Promise概念和常用api
- 【MyBatis】延迟加载
- 行人检测论文笔记:How Far are We from Solving Pedestrian Detection?
- 知识点:XSS
- 简单计算器,四则运算,小括号,实数,剔除空格,封装calculator类
- build 中的配置说明
- Linux文件操作符和文件指针的区别
- Linux安装Apache 2.4 + PHP 7 + Mysql笔记
- 火狐浏览器下burpsuite 抓取https数据包----记录一下可笑的配置过程
- 有关Android Studio里一些单位的介绍