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

Respuestas a la pregunta(7)

Su respuesta a la pregunta