我正在迭代从Native SQL查询获得的对象,以便能够打印一个实体的属性。为此,我建议使用以下代码:
public<T> ArrayList exectuteStoreProcedure(String sqlQuery){
setEntities();
int colcount = 0;
int rowcount = 0;
int rowcounter = 0;
ArrayList a = new ArrayList();
try{
Query query = em.createNativeQuery(sqlQuery);
rowcount = query.getResultList().size();
colcount = ((Class[]) query.getResultList().get(0)).length;
String [][] array = new String [rowcount][colcount];
for (Iterator<String[]> rs = query.getResultList().iterator(); rs.hasNext();) {
String[] obj = rs.next();
String[] record = new String[colcount];
System.arraycopy(obj, 0, record, 0, colcount);
array[ rowcounter++] = (String[]) record;
}
a.add(array);
}catch(Exception ex){
et.rollback();
}
closeEntities();
return a;
}
执行失败会抛出以下异常:
java.lang.ClassCastException:[Ljava.lang.Object;无法转换为[Ljava.lang.Class;
在debbug模式下运行程序后,我发现问题在于此命令行上的(Class [])声明:
colcount = ((Class[]) query.getResultList().get(0)).length;
我想知道如何获得列长度。有谁知道怎么样?我的实体是Idioma,它由String palabra,String idioma和int wordID组成;
提前致谢!
答案 0 :(得分:1)
错误说明了一切,那不是Class的数组,它是Object的数组。您可以更改演员阵容并使用:
colcount = ((Object[]) query.getResultList().get(0)).length;