Java MongoTemplate查询返回指定字段(内嵌集合)及指定数量的数据

本文介绍如何在MongoDB中仅查询Article实体中的Comment列表,并讨论了如何限制返回的Comment数量,包括使用projection和slice方法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

假设我有一个实体类Article

@Data
@Document(collection = "articles")
public final class Article {
    @Id
    private String id;
    private String name;
    private String url;
    private String author;
    private List<Comment> comments;
}

实体类Comment

@Data
public final class Comment {
    private String userId;
    private String content;
}

 

已经通过测试用例添加进去几条数据,假设其中一个Article的_id为5b5694f38ec9b636c4e52d69
可以通过MongoRepository获取到这个id的Article,也可以通过MongoTemplate获取

final String id = "5b5694f38ec9b636c4e52d69";
Query query = new Query()
              .addCriteria(Criteria.where("id").is(id));
Article article = mongoTemplate.findOne(query, Article.class);

这样可以获取到,现在我想只获取这个Article的List<Comment>

Document queryObject = new Document();
queryObject.put("id", id);

Document fieldsObject = new Document();
fieldsObject.put("id", false);
fieldsObject.put("comments", true);

Query query = new BasicQuery(queryObject, fieldsObject);

如果我find时返回List

List comments = mongoTemplate.findOne(query, List.class);

 这样毫无疑问会出现异常,返回Article

Article article = mongoTemplate.findOne(query, Article.class);
List<Comment> comments = Optional.of(article).orElseThrow(ArticleNotFoundException::new)
                                            .getComments();

这样可以获取List<Comment>,但是这样的获取意义不是很大,也无法获取指定数量的Commit(subList()也没有什么意义)。
有没有什么方式直接返回List<Commit>呢,这样便可以使用limit()skip()
如果没有,那有没有一种方式可以实现limit() skip()同样的效果?

 

通过查找文档找到了答案

MongoCollection<Document> collection =
    mongoClient.getDatabase(YOUR_DATABASE_NAME).getCollection(YOUR_COLLECTION_NAME);
FindIterable<Document> findIterable = collection.find()
                                                .filter(eq("_id", new ObjectId(id)))
                                                .projection(fields(include("comments"), excludeId(), slice("comments", 2)));
Document document = findIterable.first();
if (document != null) {
    Object o = document.get("comments");
    if (o instanceof List) {
        List comments = (List) o;
        assert comments.size() == 2;
    }
}

 


来源于:

https://www.jianshu.com/p/e0b62a2a416d

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值