MyBatis如何支持多表联合查询
在 MyBatis 中,可以使用 resultMap 或者association 标签来实现多表联合查询。以下是两种方法的简要介绍:
- 使用 resultMap:
首先,在映射文件中定义两个 resultMap,分别对应两个表的数据结构。然后,在查询语句中使用 标签将两个表的结果映射到同一个 resultMap 中。
示例:
假设我们有两个表:user 和 order,它们的结构如下:
user 表:
CREATE TABLE user (
id INT PRIMARY KEY,
name VARCHAR(255),
email VARCHAR(255)
);
order 表:
CREATE TABLE order (
id INT PRIMARY KEY,
user_id INT,
product VARCHAR(255),
FOREIGN KEY (user_id) REFERENCES user(id)
);
首先,在映射文件中定义两个 resultMap:
<resultMap id="UserOrderResultMap" type="com.example.UserOrder">
<id property="id" column="user_id"/>
<result property="name" column="name"/>
<result property="email" column="email"/>
<collection property="orders" ofType="com.example.Order" column="user_id" select="com.example.OrderMapper.selectOrdersByUserId"/>
</resultMap>
<resultMap id="OrderResultMap" type="com.example.Order">
<id property="id" column="id"/>
<result property="productId" column="product"/>
<result property="userId" column="user_id"/>
</resultMap>
然后,在查询语句中使用 标签将两个表的结果映射到同一个 resultMap 中:
<select id="selectUserWithOrders" resultMap="UserOrderResultMap">
SELECT u.id as user_id, u.name, u.email, o.id as order_id, o.product
FROM user u
LEFT JOIN order o ON u.id = o.user_id
WHERE u.id = #{userId}
</select>
- 使用 association 标签:
在映射文件中定义一个 resultMap,并使用 标签表示表之间的关联关系。然后,在查询语句中使用 标签将表的结果映射到 resultMap 中。
示例:
使用与上面相同的 user 和 order 表结构。
首先,在映射文件中定义一个 resultMap,并使用 标签表示表之间的关联关系:
<resultMap id="UserOrderResultMap" type="com.example.UserOrder">
<id property="id" column="user_id"/>
<result property="name" column="name"/>
<result property="email" column="email"/>
<association property="orders" javaType="com.example.Order" column="user_id" select="com.example.OrderMapper.selectOrdersByUserId"/>
</resultMap>
然后,在查询语句中使用 标签将表的结果映射到 resultMap 中:
<select id="selectUserWithOrders" resultMap="UserOrderResultMap">
SELECT u.id as user_id, u.name, u.email, o.id as order_id, o.product
FROM user u
LEFT JOIN order o ON u.id = o.user_id
WHERE u.id = #{userId}
</select>
这样,通过 MyBatis 的 resultMap 或者 association 标签,就可以实现多表联合查询。
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:niceseo6@gmail.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。版权声明:如无特殊标注,文章均为本站原创,转载时请以链接形式注明文章出处。
评论