在 MyBatis 中,可以使用 resultMap 或者association 标签来实现多表联合查询。以下是两种方法的简要介绍:
首先,在映射文件中定义两个 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>
然后,在查询语句中使用
<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>
在映射文件中定义一个 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>
然后,在查询语句中使用
<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 标签,就可以实现多表联合查询。
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。