我们希望在接口方面使用DTO投影,因此我们创建了以下的DTO对象:
但是,当调用时我们会收到异常:
请注意这行文字:“……期望的参数是:java.lang.String、java.lang.String和com.example.projections.model.AddressEntity……”。显然,它期望一个模型对象AddressEntity,但当找到DTO对象(AddressDto)时会感到困惑。
因此,问题是,既然这适用于接口投影,我们也希望DTO投影也能被支持吗?通过查看GitHub上的示例(https://github.com/spring-projects/spring-data-examples/blob/master/jpa/example/src/main/java/example/springdata/jpa/projections/CustomerRepository.java)和Spring Data JPA文档中的示例,我们没有看到这种情况的例子,但我们也没有看到明确说明不支持这种情况。
@Data
@Builder
@AllArgsConstructor
public class PersonDto {
private String name;
private String email;
private AddressDto address;
}
地址传输对象
@Data
@Builder
@AllArgsConstructor
public class AddressDto {
private String address;
private String streetNumber;
}
一个代码库
@Repository
public interface PersonRepository extends JpaRepository<PersonEntity, Long> {
List<PersonDto> findAllDtoedBy();
}
但是,当调用时我们会收到异常:
Caused by: org.hibernate.hql.internal.ast.QuerySyntaxException: Unable to locate appropriate constructor on class [com.example.projections.model.PersonDto]. Expected arguments are: java.lang.String, java.lang.String, com.example.projections.model.AddressEntity [select new com.example.projections.model.PersonDto(generatedAlias0.name, generatedAlias0.email, address) from com.example.projections.model.PersonEntity as generatedAlias0 left join generatedAlias0.address as address]
at org.hibernate.hql.internal.ast.QuerySyntaxException.convert(QuerySyntaxException.java:74) ~[hibernate-core-5.2.11.Final.jar:5.2.11.Final]
at org.hibernate.hql.internal.ast.ErrorCounter.throwQueryException(ErrorCounter.java:91) ~[hibernate-core-5.2.11.Final.jar:5.2.11.Final]
at org.hibernate.hql.internal.ast.QueryTranslatorImpl.analyze(QueryTranslatorImpl.java:272) ~[hibernate-core-5.2.11.Final.jar:5.2.11.Final]
at org.hibernate.hql.internal.ast.QueryTranslatorImpl.doCompile(QueryTranslatorImpl.java:189) ~[hibernate-core-5.2.11.Final.jar:5.2.11.Final]
请注意这行文字:“……期望的参数是:java.lang.String、java.lang.String和com.example.projections.model.AddressEntity……”。显然,它期望一个模型对象AddressEntity,但当找到DTO对象(AddressDto)时会感到困惑。
因此,问题是,既然这适用于接口投影,我们也希望DTO投影也能被支持吗?通过查看GitHub上的示例(https://github.com/spring-projects/spring-data-examples/blob/master/jpa/example/src/main/java/example/springdata/jpa/projections/CustomerRepository.java)和Spring Data JPA文档中的示例,我们没有看到这种情况的例子,但我们也没有看到明确说明不支持这种情况。