当前位置: 首页 > 知识库问答 >
问题:

使用带有MongoTemplate的Spring Boot对MongoDB结果进行排序

别峻
2023-03-14

目标

我想问一下这个问题:

db.getCollection("employees").find().sort({
  hire_date: 1
}).limit(10)
    null
@Service
public class MongoService {

    @Autowired
    private MongoTemplate mongoTemplate;

    public Document simpleQuery() {

        // 1st
        mongoTemplate.aggregate(Arrays.asList(
                sort(Sorts.ascending("hire_date")),
                limit(10)
        ));

        // 2nd
        mongoTemplate.findAll(Employee.class).sort(new BasicDBObject("hire_date", 1));

        // 3rd
        mongoTemplate.findAll(Employee.class).sort((o1, o2) -> o1.getHire_date() > o2.getHire_date());

        // and more...
    }
}

我想解决方案可能非常简单,就像查询本身一样,但这些是我在这种基础上迈出的第一步。提前感谢你在这方面的任何帮助。

共有1个答案

席烨
2023-03-14

试试这个,

Aggregation aggregation = Aggregation.newAggregation(
    sort(Sort.Direction.ASC, "hire_date"),
    limit(10)
).withOptions(AggregationOptions.builder().allowDiskUse(Boolean.TRUE).build());

mongoTemplate.aggregate(aggregation, mongoTemplate.getCollectionName(Employee.class), Object.class).getMappedResults();
 类似资料:
  • 问题内容: 我在使用Elasticsearch查询时遇到问题。我希望能够对结果进行排序,但是elasticsearch忽略了排序标签。这是我的查询: 但是,当我删除查询部分并仅发送排序标签时,它就可以工作。谁能指出正确的方法? 我还尝试了以下查询,这是我所拥有的完整查询: 设定值 对应 提前致谢! 问题答案: 文档中的 “标题” 字段是一个 分析的 字符串字段,也是一个多值字段,这意味着Elast

  • 所以基本上我要做的是,我已经在弹性搜索中插入了数据,添加了地理坐标,现在我需要做的是,能够运行一个查询,对我得到的结果进行排序,从最近到最远。 我想找到我所在州的所有商店,然后按离我当前位置最近的一家订购。 因此,给定一个名为“state”的字段和一个名为“point”的字段,这是一个数组,使用elastica保存long/lat,该查询是什么? 谢谢你能给我的任何帮助。

  • 问题内容: 我在Python中有两个列表 我想对第一个列表进行排序,并使用结果对第二个列表进行排序。 换句话说,结果应为: 我知道如何分别对每个列表进行排序,但是如何使用对另一个列表进行排序所产生的索引排列来对一个列表进行排列呢? 问题答案: 施瓦兹变换

  • 问题内容: 我在解决此mongodb(猫鼬)问题时遇到很多困难。 存在此模式“推荐”(用户名,roomId,ll和日期),其集合包含对用户的推荐。 我需要获取最推荐的房间列表(按roomId)。下面是模式和我尝试过的猫鼬查询解决方案。 问题答案: 从聚合管道返回的结果只是普通对象。因此,您将排序作为流水线阶段而不是作为单独的操作进行: 因此,也可以使用多种流水线运算符 或 或 和其他东西。这些可以

  • 我目前有一个查询,它使用MongoTemplate的findAll()方法返回集合中的所有文档。我想对这些结果进行排序,但看不到任何方法。我看到我可以使用find()和一个查询参数并调用。with(Sort Sort),但是在这个场景中,我如何设置查询以返回所有文档?我会同意使用任何一种方法。

  • 我对mongodb query builder很陌生,并试图结合query builder和mongodb在php(Symfony2.6)中进行全文搜索。然后,在我的操作中,我有以下查询: 此查询返回所需的结果,但不对其进行排序。我的意思是,它不会根据与查询匹配的每个文档的得分对结果进行排序。我已经研究了mongoDb中的所有文本搜索和排序文档以及堆栈溢出解答,如php、mongoDb全文搜索和排