Ogni volta che provo a impostare un elenco come parametro da utilizzare in un'espressione IN, ottengo un'eccezione argomento non valido. Vari post su internet sembrano indicare che ciò è possibile, ma sicuramente non funziona per me. Sto usando Glassfish V2.1 con Toplink.Impostazione di un parametro come elenco per un'espressione IN
Qualcun altro è stato in grado di farlo funzionare, in caso affermativo come?
ecco qualche esempio di codice:
List<String> logins = em.createQuery("SELECT a.accountManager.loginName " +
"FROM Account a " +
"WHERE a.id IN (:ids)")
.setParameter("ids",Arrays.asList(new Long(1000100), new Long(1000110)))
.getResultList();
e la parte rilevante l'analisi dello stack:
java.lang.IllegalArgumentException: You have attempted to set a value of type class java.util.Arrays$ArrayList for parameter accountIds with expected type of class java.lang.Long from query string SELECT a.accountManager.loginName FROM Account a WHERE a.id IN (:accountIds). at oracle.toplink.essentials.internal.ejb.cmp3.base.EJBQueryImpl.setParameterInternal(EJBQueryImpl.java:663) at oracle.toplink.essentials.internal.ejb.cmp3.EJBQueryImpl.setParameter(EJBQueryImpl.java:202) at com.corenap.newtDAO.ContactDaoBean.getNotificationAddresses(ContactDaoBean.java:437) at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39) at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25) at java.lang.reflect.Method.invoke(Method.java:597) at com.sun.enterprise.security.application.EJBSecurityManager.runMethod(EJBSecurityManager.java:1011) at com.sun.enterprise.security.SecurityUtil.invoke(SecurityUtil.java:175) at com.sun.ejb.containers.BaseContainer.invokeTargetBeanMethod(BaseContainer.java:2920) at com.sun.ejb.containers.BaseContainer.intercept(BaseContainer.java:4011) at com.sun.ejb.containers.EJBObjectInvocationHandler.invoke(EJBObjectInvocationHandler.java:203) ... 67 more
e la tua JPQL è sbagliato, rimuovere le staffe – James
sbagliato. Dipende dall'implementazione con JPA 1.0 implementata da Hibernate, ma necessita di parentesi. – Guaido79
Questo era un bug in Hibernate: https://hibernate.atlassian.net/browse/HHH-5126 – Kawu