有 Java 编程相关的问题?

你可以在下面搜索框中键入要查询的问题!

java如何将新类映射到实体中的现有类?

我在实体中拥有这两处财产:

@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

有没有什么建议可以做到这一点,或者有没有可能


共 (1) 个答案

  1. # 1 楼答案

    你不能绘制地图,但你不需要这样做。您可以根据需要或在加载后生命周期侦听器中创建此集合:

    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数据投影。其思想是以您喜欢的方式定义目标结构(域模型),并通过JPQL表达式将属性(getter)映射到实体模型

    在Blaze持久性实体视图中,您的用例的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数据集成允许您像Spring数据投影一样使用它:https://persistence.blazebit.com/documentation/entity-view/manual/en_US/index.html#spring-data-features

    Page<OrderDto> findAll(Pageable pageable);
    

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