JPA que pasa la lista a la cláusula IN en la consulta nativa con nombre
Sé que puedo pasar una lista a una consulta con nombre en JPA, pero ¿qué hay de NamedNativeQuery? He intentado de muchas maneras, pero todavía no puedo pasar la lista a una NamedNativeQuery. ¿Alguien sabe cómo pasar una lista a la cláusula in en NamedNativeQuery? ¡Muchas gracias
The NamedNativeQuery es la siguiente:
@NamedNativeQuery(
name="User.findByUserIdList",
query="select u.user_id, u.dob, u.name, u.sex, u.address from user u "+
"where u.user_id in (?userIdList)"
)
y se llama así:
List<Object[]> userList = em.createNamedQuery("User.findByUserIdList").setParameter("userIdList", list).getResultList();
Sin embargo, el resultado no es el que esperaba.
System.out.println(userList.size()); //output 1
Object[] user = userList.get(0);
System.out.println(user.length); //expected 5 but result is 3
System.out.println(user[0]); //output MDAVERSION which is not a user_id
System.out.println(user[1]); //output 5
System.out.println(user[2]); //output 7