微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

将多对多关系映射到 DTO 对象

如何解决将多对多关系映射到 DTO 对象

您好,我想将实体类映射到 DTO 对象。

订单类:

@Data
@AllArgsConstructor 
@NoArgsConstructor
@Entity 
@Table(name = "ORDERS")
public class Order extends BaseEntity {

    @Column(name = "ORDER_DATE")
    private LocalDateTime orderDate;

    @Column(name = "TOTAL_PRICE")
    private double totalPrice;

    @OnetoMany(mappedBy = "order")
    Set<OrderPart> orderParts;
}

产品类别:

@Data 
@AllArgsConstructor 
@NoArgsConstructor
@Entity 
@Table(name = "PRODUCT")
public class Product extends BaseEntity {

    @Column(name = "NAME")
    private String name;

    @Column(name = "PRICE")
    private double price;

    @OnetoMany(mappedBy = "product")
    Set<OrderPart> orderParts;
}

订单零件类:

@Data
@AllArgsConstructor 
@NoArgsConstructor
@Entity 
@Table(name = "ORDER_PART")
public class OrderPart extends BaseEntity {

    @Column(name = "QUANTITY")
    private int quantity;

    @ManyToOne
    @JoinColumn(name = "ORDER_ID")
    Order order;

    @ManyToOne
    @JoinColumn(name = "PRODUCT_ID")
    Product product;

    public double getPriceOfProduct() {
        return product.getPrice();
    }
}

此时我正在使用 mapstruct 中的映射器:

@Mapper(componentModel = "spring")
public interface WarehouseApiMapper {
    WarehouseApiMapper mapper = Mappers.getMapper(WarehouseApiMapper.class);

    @Mapping(target = "orderDate",dateFormat = "yyyy-MM-dd HH:mm")
    OrderDto OrderToOrderDto(Order order);
}

还有我的 DTO 课

@Data
public class OrderDto {

    private Integer id;
    private String orderDate;
    private Double totalPrice;
    private Set<ProductDto> products;

    public OrderDto(String orderDate,Double totalPrice) {
        this.orderDate = orderDate;
        this.totalPrice = totalPrice;
    }
}

我想将此关系映射到我的 OrderDto 对象。有没有办法自动映射它,或者我必须编写自己的映射器?感谢您的回答。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。