版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
一对一
商品订单模型
需求:查询所有订单信息,关联查询下单用户信息。
注意:一个用户可以有多个订单信息,一个订单只能对应一个用户
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();
}
结果: