在 MyBatis 中,可以使用动态 SQL 功能来实现连表查询。MyBatis 提供了、
和
首先,假设我们有两个数据库表:user
和 order
,它们之间的关系是一个用户可以有多个订单。
- 创建 User 和 Order 的实体类:
public class User { private int id; private String name; private Listorders; // getter and setter methods } public class Order { private int id; private String orderNumber; private int userId; // getter and setter methods }
- 在 MyBatis 的映射文件中定义两个表的映射:
- 在同一个映射文件中定义连表查询的 SQL 语句:
- 创建一个 UserMapper 接口,用于与映射文件关联:
package com.example.mapper; import java.util.List; import com.example.entity.User; public interface UserMapper { User getUserWithOrders(int userId); }
- 最后,在你的业务逻辑中调用 UserMapper 的
getUserWithOrders
方法来获取用户及其订单信息:
@Autowired private UserMapper userMapper; public User getUserWithOrders(int userId) { return userMapper.getUserWithOrders(userId); }
这样,你就可以使用 MyBatis 的动态 SQL 功能实现两个表的连接查询了。根据实际需求,你还可以使用
、
、
等元素来构建更复杂的动态 SQL 查询。