我正在使用JPA查詢獲取值並將結果放入列表中,但在服務類中,當我嘗試將實體轉換爲DTO ..我得到錯誤「Ljava.lang.Object;無法投射到entityClass「 ...我試過forloop,forEach循環和迭代器出錯。當我嘗試獲取第一個元素並將其放入entityclass對象時,我得到這個錯誤。[Ljava.lang.Object;不能轉換爲entityClass
List<Dashboard> dashboard = (List<Dashboard>)dashboardRepository.findAll();
System.out.println("AllSolCount Length :------------------------------- "+dashboard.size());
List<DashboardDto> result = new ArrayList<DashboardDto>();
System.out.println("List Elements :----------------------------------- "+dashboard);
/*for(int i=0;i<dashboard.size();i++) {
**Dashboard obj = (Dashboard)dashboard.get(i); //error in this line I get**
DashboardDto dashboardDto = mapToDto(obj, DashboardDto.class, false);
result.add((DashboardDto) dashboardDto);
}
for (Dashboard obj : dashboard){
**DashboardDto dashboardDto = mapToDto(obj, DashboardDto.class, false);// error in this line I get**
result.add((DashboardDto) dashboardDto);
}*/
Iterator itr = dashboard.iterator();
while(itr.hasNext()){
**Dashboard obj = (Dashboard) itr.next(); // error here itself**
}
return result;
線雙*在哪裏誤差每個循環彈出的那些。請大家給點建議
在檢索從DB我正在返回實體類的列表數據,但而不是實體類的列表我得到的Java對象列表..所以我想可能是一些配置或缺少某些東西。
對我來說它的自定義查詢 @Query(value =「SELECT sol.offering,sol.state,COUNT(sol.id)FROM Solution sol GROUP BY sol.offering,sol.state「) public List findAll();
上有如此衆多的非常類似的問題,都指向同一個原因(如https://stackoverflow.com/questions/27280818/java-lang-classcastexception-ljava-lang-object-cannot-be -cast-to-entity-usere)你看過那些嗎? – fvu
[java.lang.ClassCastException:\ [Ljava.lang.Object;不能轉換爲entity.UserEntity](https://stackoverflow.com/questions/27280818/java-lang-classcastexception-ljava-lang-object-cannot-be-cast-to-entity-usere) – araknoid
答案在於你的截圖。 您的存儲庫不會返回'List'。它返回一個'List