栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

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

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

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 ordersList;//用户关联的订单
 setter/getter方法
}

用户mapper接口


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

用户的mapper映射文件





 
  
  
  
  
  
   
   
  
 
 
 
  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}
 

用户业务层接口


public interface UserWithOrdersInfo {
 List selectUserOrdersInfo(int id);
}

用户业务层实现类

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

 @Override
 public List 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";
 }
}

页面




 
 person信息页面


用户id 姓名 用户地址 订单id 订单号
用户id 用户姓名 用户地址 订单id 订单号 订单id 订单号

运行结果

一对多关联关系总结:

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

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

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/135280.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号