Можно ли использовать объект Array в качестве параметра в аннотации Spring Repository @Query?
Я пытаюсь получить все строки в таблице, чей узел столбца присутствует в массиве строк. Можно ли сделать это одновременно, используя аннотацию @Query в репозитории Spring?
Вот мой объект местоположения:
@Entity
@Table(name = "LOCATIONS")
public class Location extends Measurement{
private String latitude;
private String nsIndicator;
private String longitude;
private String ewIndicator;
@ManyToOne
@JoinColumn(name="node")
private Node node;
}
Где node ссылается на класс Node, и он отображается в базе данных как BIGINT.
У меня есть такой репозиторий:
public interface LocationRepository extends CrudRepository<Location, Long>{
@Query(value=
"SELECT l1.node, l1.id, l1.latitude, l1.longitude " +
"FROM LOCATIONS l1 WHERE l1.node IN (:ids)",
nativeQuery=true)
List<Location> findMeasureByIds(@Param("ids") String[] ids);
}
Там вы можете увидеть запрос, который я пытаюсь выполнить, но он не работает. Я не знаю, можно ли там использовать массив, или параметры должны быть просто строками и/или целыми числами, я нигде не мог найти.
Я пробовал несколько комбинаций, таких как использование простой строки с правильным форматом или длинного массива... но пока ничего не сработало.
Заранее спасибо.
РЕШЕНИЕ:
@Query(value="SELECT * FROM LOCATIONS l1 " +
"INNER JOIN (SELECT node, MAX(id) AS id FROM LOCATIONS GROUP BY node) l2 " +
"ON l1.node = l2.node AND l1.id = l2.id " +
"WHERE l1.node IN :ids", nativeQuery=true)
List<Location> findLastLocationByIds(@Param("ids") Set<Long> ids);
Я добавил больше функциональности в запрос, потому что мне нужно было получить последнюю строку, вставленную для каждого идентификатора узла. Итак, для этой работы есть функция MAX и ВНУТРЕННЕЕ СОЕДИНЕНИЕ.