2016-04-06 88 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

'[Ljava.lang.Object'不'java.lang.Object',它的'對象[]'。解壓數組。 – chrylis

回答

1

你似乎省略該呼叫的實體類型:

Query l_query = l_em.createNativeQuery(p_query); 

嘗試用

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

不,請參閱上面的函數我正在設置類名 –

+0

是的,但你不會將它傳遞給'createNativeQuery'。你可以試試嗎?看看這個部分_3.4.1.6_這裏:https://docs.jboss.org/hibernate/entitymanager/3.6/reference/en/html_single/#query_native – Berger

+0

是的,它解決了你是正確的通過類 –

相關問題