Mybatis中collection和association的使用区别详解

文章目录

  • 1、关联-association

  • 2、集合-collection

  • 比如一个User类中有Role对象;Roles的对象集合。
    在这里插入图片描述

  • 在映射role属性时用association标签,映射roles时用collection标签。

  • 所以association是用于一对一和多对一,而collection是用于一对多的关系。

  • xml结构中关联对象和对象集合:
    在这里插入图片描述

  • 注意上面association 关联时的主键,查询出来select对应的属性。

  • 使用的sql语句:
    在这里插入图片描述

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
MyBatis,associationcollection是resultMap属性用于定义关联对象和集合对象映射规则的元素。 1. association:用于定义关联对象的映射规则。它可以在一个resultMap嵌套另一个resultMap,以实现对象之间的关联映射。常见的应用场景是一对一的关联关系。 association元素可以包含以下属性: - property:指定关联对象在Java对象的属性名。 - column:指定关联字段在数据库的列名。 - resultMap:指定关联对象的resultMap,用于定义关联对象的映射规则。 示例: ```xml <resultMap id="userResultMap" type="User"> <id property="id" column="user_id"/> <result property="username" column="username"/> <association property="role" resultMap="roleResultMap"/> </resultMap> ``` 2. collection:用于定义集合对象的映射规则。它可以将查询结果的多行数据映射为一个集合对象,常见的应用场景是一对多的关联关系。 collection元素可以包含以下属性: - property:指定集合对象在Java对象的属性名。 - ofType:指定集合元素的类型。 - column:指定关联字段在数据库的列名。 - resultMap:指定集合元素的resultMap,用于定义集合元素的映射规则。 示例: ```xml <resultMap id="orderResultMap" type="Order"> <id property="id" column="order_id"/> <result property="orderNo" column="order_no"/> <collection property="items" ofType="OrderItem" resultMap="orderItemResultMap"/> </resultMap> ``` 通过使用associationcollection元素,我们可以定义复杂的对象关系映射,使查询结果能够直接转换为Java对象及其关联对象或集合对象。这样可以方便地进行对象间的关联查询和数据封装。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值