2016-04-06 3 views
1

私はネイティブクエリを作成し、結果のリストを取得していますにキャストし、私はラベルのものを表示したいが、これはするための方法であるjava.lang.Objectの、Backed.Bean

private void requestsButtonClicked() { 
    try { 
    String l_query = ""; 
    l_query = "SELECT * from tablename"; 
    Controller controller = new Controller(ui.getDbConnection()); 
    List<RequestBean> l_list = l_ric.getNativeQueryResult(l_query, RequestBean.class); 
    m_requestResultNumber.setCaption(l_list.size() + ""); 
    } catch (Exception e) { 
    m_logger.error("CATCH", e); 
    org.ids.geoais.common.Process.showErrorMessage(m_RefGeoAISui, e); 
    } 
} 

エラーを得たことはできませんネイティブクエリあなたはこの呼び出しでエンティティ・タイプを省略するように見える

public <T> List<T> getNativeQueryResult(String p_query, Class<T> p_class) throws Exception { 
    m_logger.debug("BaseController::getNativeQueryResult()"); 
    // TODO Auto-generated method stub 
    m_logger.debug("SQL = " + p_query); 
    List<T> l_returnList = new ArrayList<T>(); 
    EntityManager l_em = m_connectionInstance.getEntityManager(); 
    Query l_query = l_em.createNativeQuery(p_query); 
    for (Object l_obj : l_query.getResultList()) { 
    if (null != l_obj) { 
     if (p_class.isAssignableFrom(l_obj.getClass())) { 
     l_returnList.add(p_class.cast(l_obj)); 
     } else { 
     m_logger.warn("Cannot cast the object of type " + l_obj.getClass().getName() + " to object of type " + p_class.getName()); 
     } 
    } else { 
     m_logger.warn("Search object in get query result is NULL"); 
    } 
    } 
    return l_returnList; 
} 

Error: [2016-04-06 11:51:38,406] - WARN - (db.BaseController) - Cannot cast the object of type [Ljava.lang.Object; to object of type backend.bean [2016-04-06 11:51:38,406] - WARN - (db.BaseController) - Cannot cast the object of type [Ljava.lang.Object; to object of type backend.bean [2016-04-06 11:51:38,406] - WARN - (db.BaseController) - Cannot cast the object of type [Ljava.lang.Object; to object of type backend.bean

+1

で試してみてください。配列を展開します。 – chrylis

答えて

1

Query l_query = l_em.createNativeQuery(p_query); 

は `[Ljava.lang.Object`は` java.lang.Object`が、それは `` []オブジェクトのされていない

Query l_query = l_em.createNativeQuery(p_query, p_class); 
+0

No上記の関数を見てください。私はクラス名を設定しています –

+0

はい、 'createNativeQuery'に渡しません。試してみてください。ここでセクション_3.4.1.6_を見てください:https://docs.jboss.org/hibernate/entitymanager/3.6/reference/en/html_single/#query_native – Berger

+0

はい、それを解決しました。クラスを通過するのは正しいです。 –

関連する問題