【JavaEE】MyBatis resultMap与resultType 多表查询 (一对一 + 一对多) 详解

14 篇文章 0 订阅
4 篇文章 0 订阅

1. resultMpa 与 resultType

1.1 resultType

使用mybatis进行增 删 改操作时,可以不设置返回类型,默认是返回受影响的行数
在这里插入图片描述

然而在使用 MyBatis 进行查询操作时候,一定要设置至少两个属性:

  • id属性:用于标识实现接口中的那个方法;
  • 结果映射属性:结果映射有两种实现标签:resultMap 和 resultType

前面因为我们数据库中的表的字段名称和对象的属性名称是一摸一样的,所以就都使用了 resultType 进行映射 :
以userinfo 表为列:
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
resultType 优点是使⽤⽅便,直接定义到某个实体类即可。

对象关系能够一对一的映射上,如果在字段与属性名称不一致时候,就需要使用 resultMap 进行相应的设置

1.2 resultMap

返回字典映射:resultMap
resultMap 使⽤场景:

  • 字段名称和程序中的属性名不同的情况,可使⽤ resultMap 配置映射;
  • ⼀对⼀和⼀对多关系可以使⽤ resultMap 映射并查询数据

如果出现字段名称与属性名称不一致时候可以使用resultMap配置映射,具体操作如下:
在这里插入图片描述
在这里插入图片描述
mapper.xml代码如下:
在这里插入图片描述
通过单元测试尝试获取查询的username:
在这里插入图片描述
发现是获取不到的(null):
在这里插入图片描述
这个时候就可以使⽤ resultMap 了,resultMap 的使用如下:
在这里插入图片描述
手动设置了数据库中的username字段和对象的name属性映射,此时就可以正确获取到结果了:
在这里插入图片描述
在这里插入图片描述
此时就能成功获取:
在这里插入图片描述

2. 多表查询

2.1 ⼀对⼀

讲解一对一时候,假设数据库中的一篇文章对应一个作者:

在这里插入图片描述
同时在article表的实体类要实现一个user表对应的外键:
在这里插入图片描述

在使用多表查询时候,一定要设置好两张表的resultMap :
user表的resultMap:
在这里插入图片描述
article表的resultMap:
在这里插入图片描述
⼀对⼀映射要使用 association 标签 :

在这里插入图片描述
同时需要设置columnPrefix ;如果省略,并且恰好两个表中如果有相同的字段,那么就会导致查询出错,示例如下:

userinfo 表中有 id 字段,articleinfo 中也有⼀个 id 字段,会导致查询出错结果如下:
在这里插入图片描述
此时假设文章的id是1,用户id是2,查询出来的用户id结果就会被先查询出来的文章id 1 覆盖,导致显示的用户id为1,实际上为2,而出错;
(两张表字段相同的情况下重名的字段会被第一次查询出来的字段值覆盖)

此时为了解决这个问题就需要使用 columnPrefix 来设置表的前缀了,避免出现字段重名的情况:

并且在进行多表查询时候需要写对多表查询的SQL(left join…on…):

ArticleMapper接口如下:
在这里插入图片描述

xml如下:

<select id="getArticleById" resultMap="BaseMap">
        select a.*,u.id u_id,u.username u_username,u.password u_password from articleinfo a left join userinfo u on a.uid=u.id where a.id=#{id}
    </select>

在这里插入图片描述
单元测试:
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

  • 多表查询(一对一部分)over ~

2.2 一对多

在学习了一对一部分之后,mybatis实现一对多查询就很容易理解啦~
这里依旧以文章表和用户表举列,一个用户可以拥有多篇文章,所以用户与文章的关系就是一对多;
在实现用户实体类的时候就需要加上文章表集合(list),表示用户与文章为一对多的关系;
在这里插入图片描述
mapper接口里面实现根据用户id查询用户以及对应拥有的文章
在这里插入图片描述
然后在对应的xml文件中实现对应的一对多SQL:
在这里插入图片描述
重点:实现resultMap:
在这里插入图片描述
注意:columnPrefix填的前缀是啥,对应的SQL书写也应该遵守:
在这里插入图片描述
执行单元测试:
在这里插入图片描述
根据用户id查询用户信息成功:
在这里插入图片描述
以及查询到用户对应的文章信息:
在这里插入图片描述

  • 多表查询,一对多查询成功 ~

  • over ~

  • 5
    点赞
  • 17
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
MyBatis是一个开源的持久层框架,它可以帮助我们简化JavaEE应用程序中的数据库访问操作。在MyBatis中,一对多嵌套查询是指在查询结果中包含了一个对象和该对象所关联的多个子对象。 在JavaEE中使用MyBatis进行一对多嵌套查询的步骤如下: 1. 定义实体类:首先需要定义两个实体类,一个是主对象的实体类,另一个是子对象的实体类。主对象实体类中需要包含一个子对象的集合属性。 2. 编写Mapper接口:创建一个Mapper接口,其中定义了查询方法,使用@Results和@Result注解来映射查询结果到实体类中。 3. 编写Mapper XML文件:在Mapper XML文件中编写SQL语句,使用嵌套查询的方式来获取主对象和子对象的数据,并通过resultMap将查询结果映射到实体类中。 4. 调用Mapper接口:在Java代码中调用Mapper接口的方法来执行查询操作,获取一对多嵌套查询的结果。 下面是一个示例代码,演示了如何使用MyBatis进行一对多嵌套查询: 1. 定义主对象实体类: ```java public class Order { private int id; private String orderNo; private List<OrderItem> orderItems; // 省略getter和setter方法 } ``` 2. 定义子对象实体类: ```java public class OrderItem { private int id; private String productName; // 省略getter和setter方法 } ``` 3. 编写Mapper接口: ```java public interface OrderMapper { @Results(id = "orderResultMap", value = { @Result(property = "id", column = "id"), @Result(property = "orderNo", column = "order_no"), @Result(property = "orderItems", column = "id", javaType = List.class, many = @Many(select = "com.example.mapper.OrderItemMapper.findByOrderId")) }) @Select("SELECT * FROM orders WHERE id = #{id}") Order findById(int id); } ``` 4. 编写Mapper XML文件: ```xml <mapper namespace="com.example.mapper.OrderMapper"> <resultMap id="orderResultMap" type="com.example.entity.Order"> <id property="id" column="id"/> <result property="orderNo" column="order_no"/> <collection property="orderItems" ofType="com.example.entity.OrderItem"> <id property="id" column="id"/> <result property="productName" column="product_name"/> </collection> </resultMap> <select id="findById" resultMap="orderResultMap"> SELECT * FROM orders WHERE id = #{id} </select> </mapper> ``` 5. 调用Mapper接口: ```java public class Main { public static void main(String[] args) { SqlSessionFactory sqlSessionFactory = ...; // 初始化SqlSessionFactory try (SqlSession sqlSession = sqlSessionFactory.openSession()) { OrderMapper orderMapper = sqlSession.getMapper(OrderMapper.class); Order order = orderMapper.findById(1); System.out.println("订单号:" + order.getOrderNo()); System.out.println("订单项:"); for (OrderItem orderItem : order.getOrderItems()) { System.out.println("商品名称:" + orderItem.getProductName()); } } } } ```
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值