从SQL JPA Native Query迭代结果时出现问题

时间:2014-09-02 18:04:25

标签: java sql jpa

我正在迭代从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组成;

提前致谢!

1 个答案:

答案 0 :(得分:1)

错误说明了一切,那不是Class的数组,它是Object的数组。您可以更改演员阵容并使用:

colcount = ((Object[]) query.getResultList().get(0)).length;