Spring CrudRepository findByInventoryIds(List<Long> inventoryIdList) - equivalent to IN clause

Espresso picture Espresso · Sep 24, 2013 · Viewed 199.2k times · Source

In Spring CrudRepository, do we have support for "IN clause" for a field? ie something similar to the following?

 findByInventoryIds(List<Long> inventoryIdList) 

If such support is not available, what elegant options can be considered? Firing queries for each id may not be optimal.

Answer

Oliver Drotbohm picture Oliver Drotbohm · Sep 25, 2013

findByInventoryIdIn(List<Long> inventoryIdList) should do the trick.

The HTTP request parameter format would be like so:

Yes ?id=1,2,3
No  ?id=1&id=2&id=3

The complete list of JPA repository keywords can be found in the current documentation listing. It shows that IsIn is equivalent – if you prefer the verb for readability – and that JPA also supports NotIn and IsNotIn.