Я создал NamedQuery, который выглядит так:
@NamedQuery(name = "EventLog.viewDatesInclude",
query = "SELECT el FROM EventLog el WHERE el.timeMark >= :dateFrom AND "
+ "el.timeMark <= :dateTo AND "
+ "el.name IN (:inclList)")
Что я хочу сделать, это указать параметр: inclList со списком элементов вместо одного элемента. Например, если у меня есть new List<String>() { "a", "b", "c" }
, как я могу получить это в параметре: inclList? Это позволяет мне кодифицировать одну строку. Например:
setParameter("inclList", "a") // works
setParameter("inclList", "a, b") // does not work
setParameter("inclList", "'a', 'b'") // does not work
setParameter("inclList", list) // throws an exception
Я знаю, что могу просто построить строку и построить из нее весь запрос, но я хотел избежать накладных расходов. Есть ли лучший способ сделать это?
Связанный вопрос: если Список очень велик, есть ли хороший способ построения такого запроса?