Mybatis<一对一,一对多><association ,collection >

MyBatis实现一对一关联查询

用户和地址 一个用户对应一个地址

User和Address实体类:

public class User {
    private Integer id;
    private String username;
    private Address address;

    // Getters and setters (省略)...
}

public class Address {
    private Integer id;
    private String city;

    // Getters and setters (省略)...
}

接口UserMapper,并在其中定义一对一关联查询的方法:

public interface UserMapper {
    User getUserWithAddressById(Integer id);
}

在MyBatis的映射文件UserMapper.xml中,我们可以使用标签实现一对一关联查询:

<!-- 定义Address的结果映射 -->
<resultMap id="addressMap" type="Address">
  <id property="id" column="address_id"/>
  <result property="city" column="city"/>
</resultMap>

<!-- 定义User的结果映射,包含对Address对象的关联映射 -->
<resultMap id="userMap" type="User">
  <id property="id" column="user_id"/>
  <result property="username" column="username"/>
  <!-- 其他User属性的映射... -->
  <association property="address" resultMap="addressMap"/>
</resultMap>

<!-- 定义查询语句,通过resultMap属性引用userMap结果映射 -->
<select id="getUserWithAddressById" resultMap="userMap">
  SELECT u.id as user_id, u.username, a.id as address_id, a.city
  FROM users u
  INNER JOIN addresses a ON u.address_id = a.id
  WHERE u.id = #{id}
</select>
  • Address类的结果映射addressMap
  • userMap结果映射中,使用**标签指定了属性address与结果映射addressMap**的关联。
  • 在查询语句中通过resultMap属性引用了userMap结果映射。
<association property="propertyName" resultMap="resultMapId"/>

****标签用于实现一对一的关联查询。它可以将查询结果中的一个字段(通常是外键)与另一个实体类的对象关联起来。

  • property:指定Java对象中的属性名,用于表示关联对象的属性。
  • resultMap:指定关联对象的结果映射id,即关联对象的****标签的id。

MyBatis实现一对多关联查询

用户和订单,一个用户对应多个订单

假设有两个实体类User和Order,一个用户对应多个订单:

public class User {
    private Integer id;
    private String username;
    private List<Order> orders; // 一对多关联,使用List集合保存订单对象

    // Getters and setters (省略)...
}

public class Order {
    private Integer id;
    private String orderNumber;

    // Getters and setters (省略)...
}

UserMapper中,定义一对多关联查询的方法:

public interface UserMapper {
        User getUserWithOrdersById(Integer id);
}

在MyBatis的映射文件UserMapper.xml中,使用嵌套结果映射来实现一对多关联查询:

<!-- 定义Order的结果映射 -->
<resultMap id="orderMap" type="Order">
  <id property="id" column="order_id"/>
  <result property="orderNumber" column="order_number"/>
  <!-- 其他Order属性的映射... -->
</resultMap>

<!-- 定义User的结果映射,包含对Order对象的嵌套映射 -->
<resultMap id="userMap" type="User">
  <id property="id" column="user_id"/>
  <result property="username" column="username"/>
  <!-- 其他User属性的映射... -->
  <collection property="orders" resultMap="orderMap"/>
</resultMap>

<!-- 定义查询语句,通过resultMap属性引用userMap结果映射 -->
<select id="getUserWithOrdersById" resultMap="userMap">
  SELECT u.id as user_id, u.username, o.id as order_id, o.order_number
  FROM users u
  LEFT JOIN orders o ON u.id = o.user_id
  WHERE u.id = #{id}
</select>
  • Order类的结果映射orderMap
  • User类的结果映射userMap。在userMap结果映射中,使用**标签指定了属性orders与结果映射orderMap**的嵌套关联
  • 在查询语句中通过resultMap属性引用了userMap结果映射。
<collection property="propertyName" ofType="elementType" resultMap="resultMapId"/>

常用属性:

  • property:指定Java对象中的属性名,用于表示关联对象的集合属性。
  • ofType:指定集合中元素的类型,即关联对象的类型。
  • resultMap:指定关联对象的结果映射id,即关联对象的****标签的id。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值