mybatis04关联关系映射

简介: mybatis04关联关系映射

1、什么是关联关系?


关联关系是指类之间的引用关系,如果类A与类B关联,那么类A将被定义成类B的属性。

例如:

public class A{
   private String name;
}
public class B{
   private String sid;
   private Float score;
   private Address address;   
}


2、关联关系的分类


一对一,一对多,多对一,多对多


       2.1一个人负责多个项目开发,例如:张三负责 A B C

       2.2一对多:一本书对应多种书本类型,例如:西游记 -> 神话、古典、名著

       2.3多对一:多本书指向一种书本类型,例如:西游记、山海经、聊斋志异 -> 神话

       2.4多对多:永远视为两个一对多  


3.将数据表导入数据库中


-- 一对多
-- 客户表(主表)
create table t_customer
(
  customer_id int primary key not null auto_increment,
  customer_name varchar(50) not null
);
-- 多对一
-- 订单表(从表)
create table t_order
(
  order_id int primary key not null auto_increment,
  order_no varchar(50) not null unique,
  cid int not null,
  foreign key(cid) references t_customer(customer_id)
);


4、通过 mybatis-generator 插件生成dao、mapper、model


       4.1配置mybatis-generator插件生成文件位位置

       4.2修改generatorConfig.xml配置文件的生成目录(mapper和model)及对应生成关系


5、修改Customer、Order实体类


       5.1实现序列化接口

       5.2建立实体映射关联关系(一对多、多对一)

  #一对多:一个客户对应多个订单

  private List orders=new ArrayList();

  #多对一:多个订单对应一个客户(一个订单对应一个客户)

  private Customer customer;


6、配置 mybatis 关联映射


       6.1 一对多

<resultMap id="one2many" type="Customer">
         <id column="customer_id" property="customerId"/>
         <result column="customer_name" property="customerName"/>
         <!-- 一对多的关系 -->
         <!-- property: 指的是集合属性的值, ofType:指的是集合中元素的类型 -->
         <collection property="orders" ofType="Order">
             <id column="order_id" property="orderId"/>
             <result column="order_no" property="orderNo"/>
         </collection>
     </resultMap>

注意事项,使用左外连接而非内连接!!!

       6.2 多对一

<resultMap id="many2one" type="Order">
        <id column="order_id" property="orderId"/>
        <result column="order_no" property="orderNo"/>
        <result column="cid" property="cid"/>
        <!-- 多对一的关系 -->
        <!-- property: 指的是属性的值, javaType:指的是属性的类型-->
        <association property="customer" javaType="Customer">
            <id column="customer_id" property="customerId"/>
            <result column="customer_name" property="customerName"/>
        </association>
   </resultMap>

下面是刚写的代码,我就不都放上来了

OrderMapper.java

package com.xnx.ssm.mapper;
import com.xnx.ssm.model.Order;
import com.xnx.ssm.model.vo.OrderVo;
import org.apache.ibatis.annotations.Param;
public interface OrderMapper {
    int deleteByPrimaryKey(Integer orderId);
    int insert(Order record);
    int insertSelective(Order record);
    Order selectByPrimaryKey(Integer orderId);
    OrderVo queryOrderVoByOrderId(@Param("orderId") Integer orderId);
    int updateByPrimaryKeySelective(Order record);
    int updateByPrimaryKey(Order record);
}


下面是运行效果:

无@Data注解运行效果


有@Data注解运行效果

相关文章
|
XML Oracle Java
mybatis反向生成实体类、dao层以及映射文件
mybatis反向生成实体类、dao层以及映射文件
|
2月前
|
SQL Java 数据库连接
MyBatis 的映射关系
MyBatis 核心功能之一是映射关系,支持一对一、一对多和多对多三种 ORM 映射。通过实体类与配置文件结合,开发者可灵活实现数据关联,提升数据库操作效率。
254 4
|
6月前
|
SQL XML Java
菜鸟之路Day35一一Mybatis之XML映射与动态SQL
本文介绍了MyBatis框架中XML映射与动态SQL的使用方法,作者通过实例详细解析了XML映射文件的配置规范,包括namespace、id和resultType的设置。文章还对比了注解与XML映射的优缺点,强调复杂SQL更适合XML方式。在动态SQL部分,重点讲解了`&lt;if&gt;`、`&lt;where&gt;`、`&lt;set&gt;`、`&lt;foreach&gt;`等标签的应用场景,如条件查询、动态更新和批量删除,并通过代码示例展示了其灵活性与实用性。最后,通过`&lt;sql&gt;`和`&lt;include&gt;`实现代码复用,优化维护效率。
578 5
|
8月前
|
SQL XML Java
七、MyBatis自定义映射resultMap
七、MyBatis自定义映射resultMap
241 6
|
8月前
|
Java 数据库连接 mybatis
MyBatis篇-映射关系(1-1 1-n n-n)
本文介绍了MyBatis中四种常见关系映射的配置方法,包括一对一、一对多、多对一和多对多。**一对一**通过`resultMap`实现属性与字段的映射;**一对多**以用户-角色为例,使用`&lt;collection&gt;`标签关联集合数据;**多对一**以作者-博客为例,利用`&lt;association&gt;`实现关联;**多对多**则通过引入第三方类(如UserForDept)分别在User和Dept类中添加集合属性,并配置对应的`&lt;collection&gt;`标签完成映射。这些方法解决了复杂数据关系的处理问题,提升了开发效率。
|
11月前
|
XML Java 数据库连接
Mybatis映射关系
简介:本文介绍了MyBatis框架中四种常见的关系映射方式,包括一对一、一对多、多对一及多对多。一对一通过简单属性映射实现;一对多通过在主对象中添加集合属性并使用`&lt;collection&gt;`标签映射子对象集合;多对一则利用`&lt;association&gt;`标签在主对象中映射单个子对象;多对多需引入第三方类,分别在两个主对象中添加对方的集合属性,并通过`&lt;collection&gt;`标签实现映射。
221 32
|
SQL 缓存 Java
【详细实用のMyBatis教程】获取参数值和结果的各种情况、自定义映射、动态SQL、多级缓存、逆向工程、分页插件
本文详细介绍了MyBatis的各种常见用法MyBatis多级缓存、逆向工程、分页插件 包括获取参数值和结果的各种情况、自定义映射resultMap、动态SQL
【详细实用のMyBatis教程】获取参数值和结果的各种情况、自定义映射、动态SQL、多级缓存、逆向工程、分页插件
mybatis复习04高级查询 一对多,多对一的映射处理,collection和association标签的使用
文章介绍了MyBatis中高级查询的一对多和多对一映射处理,包括创建数据库表、抽象对应的实体类、使用resultMap中的association和collection标签进行映射处理,以及如何实现级联查询和分步查询。此外,还补充了延迟加载的设置和用法。
mybatis复习04高级查询 一对多,多对一的映射处理,collection和association标签的使用
|
SQL Java 数据库连接
idea中配置mybatis 映射文件模版及 mybatis plus 自定义sql
idea中配置mybatis 映射文件模版及 mybatis plus 自定义sql
530 3
|
Java 数据库连接 mybatis
mybatis映射关系(1-1 1-n n-n)
Mybatis 中的关系映射包括一对一、一对多和多对多。一对一映射可以通过ResultMap定义属性与字段的对应。一对多示例中,User类包含List&lt;Role&gt;,在User的mapper.xml中使用&lt;collection&gt;标签。多对一的情况,如Author与Blog,Blog的ResultMap中使用&lt;association&gt;来映射Author属性。多对多时,如部门与用户,通常需要中间表,并在双方实体中通过&lt;collection&gt;引用中间类,如UserForDept,来维护关系。
下一篇
oss云网关配置