mybatis详解-关联查询_一对一、一对多(5)

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接: https://blog.csdn.net/qq_38188047/article/details/100555058

一对一

商品订单模型
在这里插入图片描述

需求:查询所有订单信息,关联查询下单用户信息。
注意:一个用户可以有多个订单信息,一个订单只能对应一个用户
sql:

SELECT
	o.id,
	o.user_id userId,
	o.number,
	o.createtime,
	o.note,
	u.username,
	u.address
FROM
	`order` o
LEFT JOIN `user` u ON o.user_id = u.id

在这里插入图片描述
方法1:
使用resultType
使用resultType,改造订单pojo类,此pojo类中包括了订单信息和用户信息
这样返回对象的时候,mybatis自动把用户信息也注入进来了
改造pojo类
在这里插入图片描述
Mapper接口
在UserMapper.java下创建:
在这里插入图片描述
Mapper.xml
在UserMapper.xml添加sql,如下

<!-- 查询订单,同时包含用户数据 -->
	<select id="queryOrderUser" resultType="orderUser">
	SELECT
		o.id,
		o.user_id userId,
		o.number,
		o.createtime,
		o.note,
		u.username,
		u.address
	FROM
		`orders` o
	LEFT JOIN `user` u ON o.user_id = u.id
	</select>

测试方法:
在UserMapperTest添加测试方法,如下:

@Test
	public void testQueryOrderUser() {
		// 获取sqlSession,和spring整合后由spring管理
		SqlSession sqlSession = this.sqlSessionFactory.openSession();
		//获取mapper对象
		UserMapper userMapper = sqlSession.getMapper(UserMapper.class);
		List<OrderUser> queryOrderUser = userMapper.queryOrderUser();
		for (OrderUser orderUser : queryOrderUser) {
			System.out.println(orderUser);
		}
		sqlSession.close();
	}

结果:
在这里插入图片描述
使用resultMap,定义专门的resultMap用于映射一对一查询结果。

一对一核心pojo类加对应的对象,xml配置
	<resultMap type="order" id="orderUserResultMap">
		<id property="id" column="id" />
		<result property="userId" column="userId" />
		<result property="number" column="number" />
		<result property="createtime" column="createtime" />
		<result property="note" column="note" />
	
		<!-- association :配置一对一属性 -->
		<!-- property:order里面的User属性名 -->
		<!-- javaType:属性类型 -->
		<association property="user" javaType="user">
			<!-- property: pojo属性id (主键);      column:表列名userId(外键) -->
			<id property="id" column="userId" />
			<result property="username" column="username" />
			<result property="address" column="address" />
		</association>
	
	</resultMap>

改造pojo类
在Order类中加入User属性,user属性中用于存储关联查询的用户信息,因为订单关联查询用户是一对一关系,所以这里使用单个User对象存储关联查询的用户信息。
改造Order如下图:
在这里插入图片描述
Mapper.xml
这里resultMap指定orderUserResultMap,如下:

<!-- 查询订单,同时包含用户数据 使用resulMap方式 -->
	<resultMap type="order" id="orderUserResultMap">
		<id property="id" column="id" />
		<result property="userId" column="userId" />
		<result property="number" column="number" />
		<result property="createtime" column="createtime" />
		<result property="note" column="note" />
	
		<!-- association :配置一对一属性 -->
		<!-- property:order里面的User属性名 -->
		<!-- javaType:属性类型 -->
		<association property="user" javaType="user">
			<!-- property: pojo属性id (主键);      column:表列名userId(外键) -->
			<id property="id" column="userId" />
			<result property="username" column="username" />
			<result property="address" column="address" />
		</association>
	
	</resultMap>

	<!-- 一对一关联,查询订单,订单内部包含用户属性 -->
	<select id="queryOrderUserResultMap" resultMap="orderUserResultMap">
	SELECT
		o.id,
		o.user_id userId,
		o.number,
		o.createtime,
		o.note,
		u.username,
		u.address
	FROM
		`orders` o
	LEFT JOIN `user` u ON o.user_id = u.id
	</select>

数据库表:
在这里插入图片描述
Mapper接口
编写UserMapper如下图:

在这里插入图片描述
测试方法
在UserMapperTest增加测试方法,如下:

@Test
	public void testQueryOrderUserResultMap() {
		// 获取sqlSession,和spring整合后由spring管理
		SqlSession sqlSession = this.sqlSessionFactory.openSession();
		//获取mapper对象
		UserMapper userMapper = sqlSession.getMapper(UserMapper.class);
		List<Order> queryOrderUser = userMapper.queryOrderUserResultMap();
		for (Order order : queryOrderUser) {
			System.out.println(order);
		}
		sqlSession.close();
	}
	

结果:
在这里插入图片描述


一对多

案例:查询所有用户信息及用户关联的订单信息。
用户信息和订单信息为一对多关系。
核心:pojo里面加数组或者集合,xml配置里面加resultMap

<resultMap type="user" id="userOrderResultMap">
		<id property="id" column="id"/>
		<result property="username" column="username"/>
		<result property="birthday" column="birthday"/>
		<result property="sex" column="sex"/>
		<result property="address" column="address"/>
		<!-- 配置一对多的关系 -->
		<!-- pojo:property属性名  ,javaType:属性类型,ofType泛型类型  -->
		<collection property="orders" javaType="list" ofType="order">
			<!-- property: pojo属性id (主键);         column:表列名oid(外键) -->
			<id property="id" column="oid"/>
			<result property="number" column="number"/>
			<result property="createtime" column="createtime"/>
			<result property="note" column="note"/>
		</collection>	
	</resultMap>

sql语句:

SELECT
		u.id,
		u.username,
		u.birthday,
		u.sex,
		u.address,
		o.id oid,
		o.number,
		o.createtime,
		o.note
	FROM
	`user` u
	LEFT JOIN `orders` o ON u.id = o.user_id

修改pojo类
在这里插入图片描述
Mapper接口
在这里插入图片描述
Mapper接口
编写UserMapper接口,如下图:

<resultMap type="user" id="userOrderResultMap">
		<id property="id" column="id"/>
		<result property="username" column="username"/>
		<result property="birthday" column="birthday"/>
		<result property="sex" column="sex"/>
		<result property="address" column="address"/>
		<!-- 配置一对多的关系 -->
		<!-- pojo:property属性名  ,javaType:属性类型,ofType泛型类型  -->
		<collection property="orders" javaType="list" ofType="order">
			<!-- property: pojo属性id (主键);         column:表列名oid(外键) -->
			<id property="id" column="oid"/>
			<result property="number" column="number"/>
			<result property="createtime" column="createtime"/>
			<result property="note" column="note"/>
		</collection>	
	</resultMap>
	<select id="queryUserOrder" resultMap="userOrderResultMap">
	SELECT
		u.id,
		u.username,
		u.birthday,
		u.sex,
		u.address,
		o.id oid,
		o.number,
		o.createtime,
		o.note
	FROM
	`user` u
	LEFT JOIN `orders` o ON u.id = o.user_id
	</select>

测试方法
在UserMapperTest增加测试方法,如下

@Test
	public void testQueryUserOrder() {
		// 获取sqlSession,和spring整合后由spring管理
		SqlSession sqlSession = this.sqlSessionFactory.openSession();
		//获取mapper对象
		UserMapper userMapper = sqlSession.getMapper(UserMapper.class);
		List<User> queryUserOrder = userMapper.queryUserOrder();
		for (User user : queryUserOrder) {
			System.out.println(user);
		}
		sqlSession.close();
	}

结果:
在这里插入图片描述

猜你喜欢

转载自blog.csdn.net/qq_38188047/article/details/100555058