首页 > 解决方案 > 如何将新类映射到实体中的现有类?

问题描述

我在实体中有这两个属性:

@OneToMany(mappedBy = "order", fetch = FetchType.LAZY)
private Set<OrderItemEntity> orderItems;

@OneToMany(mappedBy = "order", fetch = FetchType.LAZY)
@Where(clause = "interaction_code!='TERMINATE'")
private Set<OrderItemEntity> orderItemsWithoutTerminationOrders;

我现在想添加注释以将此 orderItemsWithoutTerminationOrders 映射到 orderItems。

任何建议如何做到这一点或有可能吗?

标签: javahibernate

解决方案


你不能映射它,但你不需要这样做。您可以按需或在加载后生命周期侦听器中创建此集合:

private transient Set<OrderItemEntity> orderItemsWithoutTerminationOrders;
@PostLoad
void init() {
  orderItemsWithoutTerminationOrders = orderItems.stream().filter(o -> o.getInteractionCode() != InteractionCode.TERMINATE).collect(toSet());
}

我不建议这样做,因为这是您应该使用 DTO 方法的投影,我认为这是Blaze-Persistence Entity Views的完美用例。

我创建了该库以允许在 JPA 模型和自定义接口或抽象类定义模型之间轻松映射,例如 Spring Data Projections on steroids。这个想法是您按照自己喜欢的方式定义目标结构(域模型),并通过 JPQL 表达式将属性(getter)映射到实体模型。

使用 Blaze-Persistence Entity-Views 的用例的 DTO 模型可能如下所示:

@EntityView(OrderEntity.class)
public interface OrderDto {
    @IdMapping
    Long getId();
    @Mapping("customer.name")
    String getCustomerName();
    @Mapping("orderItems[interactionCode != fully.qualified.name.InteractionCode.TERMINATE]")
    Set<OrderItemDto> getOrderItems();

    @EntityView(OrderItemEntity.class)
    interface OrderItemDto {
        @IdMapping
        Long getId();
        String getName();
    }
}

查询是将实体视图应用于查询的问题,最简单的就是通过 id 进行查询。

OrderDto a = entityViewManager.find(entityManager, OrderDto.class, id);

Spring Data 集成允许您几乎像 Spring Data Projections 一样使用它:https ://persistence.blazebit.com/documentation/entity-view/manual/en_US/index.html#spring-data-features

Page<OrderDto> findAll(Pageable pageable);

最好的部分是,它只会获取实际需要的状态!


推荐阅读