mybatis用注解实现一对多查询
时间: 2023-12-10 10:04:00 浏览: 26
在mybatis中,一对多查询可以使用注解实现。具体步骤如下:
1. 定义实体类
定义一个实体类,该实体类包含一个一对多的关联关系,如下所示:
```java
public class Order {
private Long id;
private Date createTime;
private List<OrderItem> orderItems; // 一对多关联关系
// getter和setter方法省略
}
public class OrderItem {
private Long id;
private Long orderId;
private String productName;
private Integer quantity;
// getter和setter方法省略
}
```
2. 创建Mapper接口
创建一个Mapper接口,并使用注解定义一对多查询语句,如下所示:
```java
public interface OrderMapper {
@Select("select * from order where id = #{id}")
@Results({
@Result(property = "id", column = "id"),
@Result(property = "createTime", column = "create_time"),
@Result(property = "orderItems", column = "id",
many = @Many(select = "com.example.OrderItemMapper.findByOrderId"))
})
Order findById(Long id);
}
public interface OrderItemMapper {
@Select("select * from order_item where order_id = #{orderId}")
List<OrderItem> findByOrderId(Long orderId);
}
```
在上面的注解中,@Results定义了查询结果的映射关系,@Result用于映射查询结果中的字段到实体类中的属性。@Many注解用于定义一对多关联关系,指定了查询OrderItem的方法,以及通过哪个字段进行关联。
3. 调用Mapper接口
在业务逻辑中调用Mapper接口,并传入查询参数,如下所示:
```java
Order order = orderMapper.findById(1L);
System.out.println(order.getId() + " " + order.getCreateTime());
for (OrderItem item : order.getOrderItems()) {
System.out.println(item.getId() + " " + item.getProductName() + " " + item.getQuantity());
}
```
通过调用OrderMapper的findById方法,可以查询到指定id的Order对象及其关联的OrderItem对象列表。