2016-04-06 9 views
1

ich eine native Abfrage erschaffe und Ergebnisliste bekommen, und ich will, dass in Etikett angezeigt bekam aber den Fehlerjava.lang.Object, kann nicht auf Backed.Bean gegossen werden

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); 
    } 
} 

Dies ist ein Verfahren für nativen Abfrage

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' ist nicht' java.lang.Object', ist es 'Object []'. Entpacken Sie das Array. – chrylis

Antwort

1

Sie scheinen den Entitätstyp in diesem Aufruf weglassen:

Query l_query = l_em.createNativeQuery(p_query); 

Versuchen mit

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

Nein, bitte in der obigen Funktion sehe ich Klasse Name setzen –

+0

Ja, aber Sie übergeben es nicht zu createNativeQuery. Könnten Sie es versuchen? Werfen Sie einen Blick auf Abschnitt _3.4.1.6_ hier: https://docs.jboss.org/hibernate/entitymanager/3.6/reference/en/html_single/#query_native – Berger

+0

Ja es Gelöst, dass Sie Recht hatten, die Klasse zu passieren –

Verwandte Themen