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
上创建索引
相关文章