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。