Toto funguje v případě, kdy je třída POJO podobná:
public class User {
private String id;
private String firstName;
private String lastName;
// constructors (including default), get/set methods, etc.
}
A dokumenty jsou uloženy ve sbírce user
jako například:
{ "_id" : ObjectId("604827bf8187ce707fb88681"), "firstName" : "John", "lastName" : "Doe", "_class" : "com.example.demo.User" }
Úložiště s metodou pro načtení objektů s dodaným seznamem id:
public interface UserRepository extends MongoRepository<User, String> {
@Aggregation(pipeline = { " { '$match': { '_id': { '$in': ?0 } } }" } )
List<User> findByIdsIn(List<String> ids);
}
Volání metody úložiště:
List<String> inputIds = Arrays.asList("604827d13de5773133374acc", "604827617a40155f5111b9ff");
List<User> outputList = userRepository.findByIdsIn(inputIds);
outputList
má dvě dokumenty odpovídající id z proměnné inputIds
.