gpt4 book ai didi

java - 直接向 DTO 查询结果

转载 作者:太空宇宙 更新时间:2023-11-04 09:51:11 25 4
gpt4 key购买 nike

当我尝试直接从 Spring 数据查询结果到 DTO 类时,我收到此错误

Caused by: java.lang.IllegalArgumentException: org.hibernate.QueryException: could not resolve property: owner_name of: test.dao.bean.Car [SELECT new test.dto.bean.CarOwners(c.owner_name, c.owner_nid, c.owner_phone, c.driver_name, c.driver_nid, c.driver_phone) FROM test.dao.bean.Car c] at org.hibernate.internal.ExceptionConverterImpl.convert(ExceptionConverterImpl.java:133) ~[hibernate-core-5.2.17.Final.jar:5.2.17.Final] at org.hibernate.internal.ExceptionConverterImpl.convert(ExceptionConverterImpl.java:157) ~[hibernate-core-5.2.17.Final.jar:5.2.17.Final] at org.hibernate.internal.ExceptionConverterImpl.convert(ExceptionConverterImpl.java:164) ~[hibernate-core-5.2.17.Final.jar:5.2.17.Final] at org.hibernate.internal.AbstractSharedSessionContract.createQuery(AbstractSharedSessionContract.java:670) ~[hibernate-core-5.2.17.Final.jar:5.2.17.Final] at org.hibernate.internal.AbstractSessionImpl.createQuery(AbstractSessionImpl.java:23) ~[hibernate-core-5.2.17.Final.jar:5.2.17.Final] at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) ~[na:1.8.0_152] at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62) ~[na:1.8.0_152] at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) ~[na:1.8.0_152] at java.lang.reflect.Method.invoke(Method.java:498) ~[na:1.8.0_152] at org.springframework.orm.jpa.ExtendedEntityManagerCreator$ExtendedEntityManagerInvocationHandler.invoke(ExtendedEntityManagerCreator.java:350) ~[spring-orm-5.0.7.RELEASE.jar:5.0.7.RELEASE] at com.sun.proxy.$Proxy123.createQuery(Unknown Source) ~[na:na] at org.springframework.data.jpa.repository.query.SimpleJpaQuery.validateQuery(SimpleJpaQuery.java:87) ~[spring-data-jpa-2.0.8.RELEASE.jar:2.0.8.RELEASE] ... 76 common frames omitted

这是我的查询:

@Query("SELECT new test.dto.bean.CarOwners(c.owner_name, c.owner_nid, c.owner_phone, c.driver_name, c.driver_nid, c.driver_phone) FROM car c")
public List<CarOwners> findAllCarOwners();

这是 DTO 类:

test.dto.bean;

public class CarOwners{

private String owner_name;
private Long owner_nid;
private Integer owner_phone;
private String driver_name;
private Long driver_nid;
private Integer driver_phone;

public CarOwners(String owner_name, Long owner_nid, Integer owner_phone, String driver_name, Long driver_nid, Integer driver_phone) {
this.owner_name = owner_name;
this.owner_nid = owner_nid;
this.owner_phone = owner_phone;
this.driver_name = driver_name;
this.driver_nid = driver_nid;
this.driver_phone = driver_phone;

}

public String getOwner_name() {
return owner_name;
}


public void setOwner_name(String owner_name) {
this.owner_name = owner_name;
}


public Long getOwner_nid() {
return owner_nid;
}


public void setOwner_nid(Long owner_nid) {
this.owner_nid = owner_nid;
}


public Integer getOwner_phone() {
return owner_phone;
}


public void setOwner_phone(Integer owner_phone) {
this.owner_phone = owner_phone;
}


public String getDriver_name() {
return driver_name;
}


public void setDriver_name(String driver_name) {
this.driver_name = driver_name;
}


public Long getDriver_nid() {
return driver_nid;
}


public void setDriver_nid(Long driver_nid) {
this.driver_nid = driver_nid;
}


public Integer getDriver_phone() {
return driver_phone;
}


public void setDriver_phone(Integer driver_phone) {
this.driver_phone = driver_phone;
}
}

请问有什么帮助吗?

最佳答案

Caused by: java.lang.IllegalArgumentException: org.hibernate.QueryException: could not resolve property: owner_name of: test.dao.bean.Car

显然,select 子句中的字段应该引用映射实体 (Car) 的 Java 属性名称,而不是 DTO 中的属性名称。

假设汽车是:

@Entity
@Table(name="car")
public class Car{


@Column(name="owner_name")
private String ownerName;

}

那么你应该写:

@Query("SELECT new test.dto.bean.CarOwners(c.ownerName) FROM car c") 

实际上,DTO字段的名称与@Query字符串的书写方式无关。它仅匹配 DTO 构造函数参数和 SELECT NEW 子句中的字段之间的顺序。您可以使用任何 DTO 名称,只要它们的顺序和数据类型匹配即可。

关于java - 直接向 DTO 查询结果,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/54731157/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com