有 Java 编程相关的问题?

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

java映射具有NamedNativeQuery和SqlResultSetMapping的任何集合

所以我编写本机查询,因为它们非常复杂,无法获取所有需要的数据等等。我目前面临一个通常由Hibernate/JPA等解决的问题

想象一下:

@Entity
FooEntity{
     @Id
     public Long id;
     @ManyToMany
     public List<FeeEntity> feeEntities;
}

@Entity
FeeEntity{
     @Id
     public Long id;
     @Column
     public String name;
}

还有一些DTO

FooDTO{
     private final Long id;
     private final List<FeeDTO> someStrings;

     public FooDTO(Long id, List<FeeDTO> feeDtos){
          ...
     }
}

我的@SqlResultSetMapping看起来基本上像

@SqlResultSetMapping(name = "FooDTO", 
     classes = @ConstructorResult(targetClass = FooDTO.class, columns = {
          @ColumnResult(name = "id", type = Long.class),     
          //TODO @ColumnResult(name = "feeDtos", type = FeeDtos.class)     
     })
)

命名的本机查询如下所示:

@NamedNativeQueries({
    @NamedNativeQuery(
                name = "FooData",
                query = "SELECT MAINSELECT.ID AS id, " +
                        "???" +
                        " FROM Foo MAINSELECT WHERE ... " +
                        ...,
                resultSetMapping = "FooDTO")
})

如何编写本机查询?这在没有子查询的情况下是可能的,还是我必须为结果的每个数据行执行子查询?我在心爱的谷歌上找不到什么东西


共 (1) 个答案

  1. # 1 楼答案

    这是不可能的

    SQL查询的结果总是一个表。因此没有嵌套表,因此无法将其映射到集合