コレクション:progs
{ "_id" : "ABC", "defaultDirectory" : "abc", "defaultRecvDirectory" : "abc" }
{ "_id" : "RAS", "defaultRecvDirectory" : "recv/ras" }
{ "_id" : "SND", "defaultSendDirectory" : "send/snd" }
Mongoコンソールで:
db.progs.find({"_id":{"$lt":"ZZZZZZZZZ"}}).sort({"_id":-1}).limit(1);
==> { "_id" : "SND", "defaultSendDirectory" : "send/snd" }
Javaの場合:
BasicDBObject query = new BasicDBObject();
query.put("_id", new BasicDBObject("$lt", "ZZZZZZZZZZ"));
DBCursor cursor = collection.find(query).sort(new BasicDBObject("_id","-1")).limit(1);
for (DBObject dbObject : cursor) {
System.out.println(dbObject);
}
==> { "_id" : "ABC", "defaultSendDirectory" : "abc", "defaultRecvDirectory" : "abc" }
誰かが違いを説明できますか?
並べ替えの"-1"
から引用符を削除します。
DBCursor cursor = collection.find(query).sort(new BasicDBObject("_id",-1)).limit(1);
または、ハードコーディング1/-1の代わりに、com.mongodb.operation.OrderBy
のMongodb ASC/DESC定数を使用します
例:
DBCursor cursor = collection.find(query).sort(new BasicDBObject("_id", OrderBy.DESC.getIntRepresentation())).limit(1);
MongoTemplateに基づく別のバージョン:
public List<?> findLimitedSorted(Query query, Object target, String startFrom) {
query.limit(100);
query.with(new Sort(Sort.Direction.ASC, "<field_name>"));
return getMongoTemplate().find(query, target.getClass());
}
MongoDBからソート順を使用してDBObjectsを取得する:
List<DBObject> list = new LinkedList<DBObject>();
DBCursor cursor = db.getCollection("myCol").find().sort(new BasicDBObject("_id",-1)).limit(collection.find(query).count());
while(cursur.hasNext){
list.add(cursur.next());
}
if(!list.isEmpty())
for(DBObject dbo: list){
System.out.println(dbo);
}
else
System.out.println("List is empty");
これが、フィルタ、並べ替え、制限で見つけた解決策です:
List<Bson> queryFilters = new ArrayList<>();
queryFilters.add(Filters.eq(SavedReportEntity.FIELD_USER_ID, userId));
List<Document> documents = getMongoCollection().find(searchFilter).sort(sort).limit(10).into(new ArrayList<Document>());
ドキュメントのリストが表示されるので、必要に応じて操作できます。