Spring Data,MongoDB。如何从文档的数组中获取嵌套对象(非文档 [英] Spring Data, MongoDB. How to get nested object (non-document) from document's array

查看:71
本文介绍了Spring Data,MongoDB。如何从文档的数组中获取嵌套对象(非文档的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

Mongo文档‘历史’:

@Document(collection = "histories")
@Data
public class History {
    @Id
    private String id;

    @Transient
    private final String name = MAIN_FOLDER;
    private String appleId;
    private ArrayList<Item> historyItems = new ArrayList<>();
    private ArrayList<Folder> historyFolders = new ArrayList<>();
}

文件夹型号:

@Data
public class Folder {
    private String name;
    private LocalDateTime date;
    private ArrayList<Item> historyItem = new ArrayList<>();
}

条件查询:

    public Folder findFolderByName(final String name) {
        Query query = new Query();
        query.addCriteria(Criteria.where("historyFolders.name").is(name));
        return template.findOne(query, Folder.class);
    }

我从该查询中获得了Null。抱歉,我不熟悉此技术,我找不到有关记录的数组的条件的信息。

推荐答案

您正在错误的集合上执行查询。 Folder不是集合,而只是";histories";集合中的嵌套文档。

还有:您不能只返回执行‘经典’查询的嵌套文档。您必须在客户端(您的Java代码)对其进行过滤,在客户端使用projections $elemMatch过滤和展开,或者使用聚合管道。Look at this Question: there are a lot of solutions if you need this in a query/pipeline

您的查询看起来正确。您只需更新查询执行即可使用History实体而不是Folder实体。

public History findFolderByName(final String name) {
    Query query = new Query();
    query.addCriteria(Criteria.where("historyFolders.name").is(name));
    return template.findOne(query, History.class);
}

如果您经常使用此查询,并且集合中有许多文档:请考虑在historyFolders.name上创建索引

这篇关于Spring Data,MongoDB。如何从文档的数组中获取嵌套对象(非文档的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆