Mybatis一对多关联关系映射实现过程解析

 更新时间:2020年02月07日 11:13:35   作者:jason小蜗牛  
这篇文章主要介绍了Mybatis一对多关联关系映射实现过程解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下

这篇文章主要介绍了Mybatis一对多关联关系映射实现过程解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下

一对多关联关系只需要在多的一方引入少的一方的主键作为外键即可。在实体类中就是反过来,在少的一方添加多的一方,声明一个List<另一方> 属性名 作为少的一方的属性。

用户和订单就是一对多的关系,从用户角度看就是一对多关系,从订单的角度来看就是多对一的关系。

/**
 * 订单持久化类
 */
public class Orders {
 private Integer id;
 private String number;
 setter/getter方法
}
/**
*用户持久化类
*/
public class User {
 private Integer id;
 private String username;
 private String address;
 private List<Orders> ordersList;//用户关联的订单
 setter/getter方法
}

用户mapper接口

/**
 * 用户Mapper接口
 */
public interface UserMapper {
 //用户和订单为一对多关系,那么此时应该返回一个用户list里面包含了订单信息
 List<User> userOrdersinfo(int id);//通过用户id返回它的订单信息
}

用户的mapper映射文件

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd" >
<mapper namespace="cn.jason.bootmybatis.mapper.UserMapper">

 <resultMap id="UserWithOrdersInfo" type="User">
  <id property="id" column="id"/>
  <result property="username" column="username"/>
  <result property="address" column="address"/>
  <!--一对多关系映射
   ofType表示属性集合中的元素的类型,List<Orders>属性即Orders类
  -->
  <collection property="ordersList" ofType="Orders">
   <id property="id" column="orders_id"/>
   <result property="number" column="number"/>
  </collection>
 </resultMap>
 <!--关联查询sql-->
 <select id="userOrdersinfo" parameterType="Integer" resultMap="UserWithOrdersInfo">
  select u.*,o.id as orders_id,o.number
  from tb_user u,tb_orders o
  where u.id=o.user_id and u.id=#{id}
 </select>

</mapper>

用户业务层接口

/**
 * 用户业务层接口
 */
public interface UserWithOrdersInfo {
 List<User> selectUserOrdersInfo(int id);
}

用户业务层实现类

@Service
public class UserWithOrdersInfoImpl implements UserWithOrdersInfo {
 @Autowired
 private UserMapper userMapper;

 @Override
 public List<User> selectUserOrdersInfo(int id) {
  return userMapper.userOrdersinfo(id);
 }
}

控制器类

@Controller
public class UserOrdersController {
 @Autowired
 private UserWithOrdersInfo userWithOrdersInfo;
 @RequestMapping("/userordersinfo/{id}")
 public String getUserOrdersInfo(@PathVariable int id, Model model){
  model.addAttribute("userordersinfo",userWithOrdersInfo.selectUserOrdersInfo(id));
  return "userordersinfo";
 }
}

页面

<!DOCTYPE html>
<html lang="en" xmlns:th="http://www.thymeleaf.org"
  xmlns="http://www.w3.org/1999/xhtml">
<head>
 <meta charset="UTF-8">
 <title>person信息页面</title>
</head>
<body>
<table>
 <thead>
 <tr>
  <th>用户id</th>
  <th>姓名</th>
  <th>用户地址</th>
  <th>订单id</th>
  <th>订单号</th>
 </tr>
 </thead>
 <tr th:each="userordersinfo:${userordersinfo}">
  <td th:text="${userordersinfo.id}">用户id</td>
  <td th:text="${userordersinfo.username}">用户姓名</td>
  <td th:text="${userordersinfo.address}">用户地址</td>
  <td th:text="${userordersinfo.ordersList.get(0).id}">订单id</td>
  <td th:text="${userordersinfo.ordersList.get(0).number}">订单号</td>
  <td th:text="${userordersinfo.ordersList.get(1).id}">订单id</td>
  <td th:text="${userordersinfo.ordersList.get(1).number}">订单号</td>
 </tr>
</table>
</body>
</html>

运行结果

一对多关联关系总结:

一对多关系从不同的角度看,关系是不一样的,但是最终都是一样的,在编写mapper映射文件的时候使用的是<collection>元素。也是使用嵌套查询更加方便,需要解决的问题是如何在页面展示查询出来的一对多关联关系的结果。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

相关文章

  • Springboot swagger配置过程详解(idea社区版2023.1.4+apache-maven-3.9.3-bin)

    Springboot swagger配置过程详解(idea社区版2023.1.4+apache-maven-3

    这篇文章主要介绍了Springboot-swagger配置(idea社区版2023.1.4+apache-maven-3.9.3-bin),本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2023-07-07
  • Java中while循环的使用方法举例详解

    Java中while循环的使用方法举例详解

    在Java编程语言中,while循环是基础控制结构之一,用于重复执行代码块直至满足特定条件,掌握其使用是编程的基础,文中通过代码介绍的非常详细,需要的朋友可以参考下
    2024-09-09
  • Java用文件流下载网络文件示例代码

    Java用文件流下载网络文件示例代码

    这篇文章主要介绍了Java用文件流的方式下载网络文件,大家参考使用吧
    2013-11-11
  • 解决idea中java出现无效的源发行版问题

    解决idea中java出现无效的源发行版问题

    这篇文章主要给大家介绍了关于解决idea中java出现无效的源发行版问题的相关资料,无效的源发行版是指IntelliJ IDEA无法正确识别和处理的源代码版本,这可能是由于错误的配置、缺少依赖项、不兼容的插件或其他问题导致的,需要的朋友可以参考下
    2024-01-01
  • SpringBoot配置Https访问的详细步骤

    SpringBoot配置Https访问的详细步骤

    HTTP(Hypertext transfer protocal)是一种详细规定了浏览器和万维网服务器之间相互通信的规则,通过因特网传送万维网文档的数据传送协议,这篇文章主要介绍了SpringBoot配置Https访问的详细步骤,需要的朋友可以参考下
    2024-02-02
  • springBoot使用openfeign来远程调用的实现

    springBoot使用openfeign来远程调用的实现

    这篇文章主要介绍了springBoot使用openfeign来远程调用的实现方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-03-03
  • 运行SpringBoot项目请求响应流程分析以及404和500报错的解决办法

    运行SpringBoot项目请求响应流程分析以及404和500报错的解决办法

    这篇文章主要介绍了运行Spring Boot项目请求响应流程分析以及404和500报错的解决办法,文中通过代码示例和图文讲解的非常详细,对大家的学习或工作有一定的帮助,需要的朋友可以参考下
    2024-12-12
  • Java switch 语句如何使用 String 参数

    Java switch 语句如何使用 String 参数

    这篇文章主要介绍了Java switch 语句如何使用 String 参数,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,,需要的朋友可以参考下
    2019-06-06
  • Mybatis实现一对一、一对多关联查询的方法(示例详解)

    Mybatis实现一对一、一对多关联查询的方法(示例详解)

    这篇文章主要介绍了Mybatis实现一对一、一对多关联查询的方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2023-04-04
  • Spring的@CrossOrigin注解使用与CrossFilter对象自定义详解

    Spring的@CrossOrigin注解使用与CrossFilter对象自定义详解

    这篇文章主要介绍了Spring的@CrossOrigin注解使用与CrossFilter对象自定义详解,跨域,指的是浏览器不能执行其他网站的脚本,它是由浏览器的同源策略造成的,是浏览器施加的安全限制,所谓同源是指,域名,协议,端口均相同,需要的朋友可以参考下
    2023-12-12

最新评论