これで、次と同等の処理を実行できます:
db.col.find({$in:[{Id:id1}, {Id:id2}, ..., {Id:idN}]})
$ inするフィールドを指定していないため、これは有効なクエリではありません。私はあなたが望むと思います:
db.col.find({Id:{$in:[id1, id2, ..., idN]}})
それに応じてクエリ構築コードを変更すれば、問題ないはずです。
編集:正しいコードを追加する:
public static void getDocuments(List<Integer> documentIds) {
BasicDBList docIds = new BasicDBList();
docIds.addAll(documentIds)
DBObject inClause = new BasicDBObject("$in", docIds);
DBObject query = new BasicDBObject("Id", inClause);
DBCursor dbCursor = mongoRule.getDatabase().getCollection("mycollection").find(query);
System.out.println(dbCursor == null);
if (dbCursor != null) {
while (dbCursor.hasNext()) {
System.out.println("object - " + dbCursor.next());
}
}
}
これは、「Id」が「_id」以外のものであることを前提としていることに注意してください