本文介紹了Spring Data,MongoDB。如何從文檔的數(shù)組中獲取嵌套對象(非文檔的處理方法,對大家解決問題具有一定的參考價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)吧!
問題描述
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。抱歉,我不熟悉此技術(shù),我找不到有關(guān)記錄的數(shù)組的條件的信息。
推薦答案
您正在錯誤的集合上執(zhí)行查詢。
Folder不是集合,而只是";histories";集合中的嵌套文檔。
還有:您不能只返回執(zhí)行‘經(jīng)典’查詢的嵌套文檔。您必須在客戶端(您的Java代碼)對其進(jìn)行過濾,在客戶端使用projections $elemMatch過濾和展開,或者使用聚合管道。Look at this Question: there are a lot of solutions if you need this in a query/pipeline。
您的查詢看起來正確。您只需更新查詢執(zhí)行即可使用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);
}
如果您經(jīng)常使用此查詢,并且集合中有許多文檔:請考慮在historyFolders.name上創(chuàng)建索引
這篇關(guān)于Spring Data,MongoDB。如何從文檔的數(shù)組中獲取嵌套對象(非文檔的文章就介紹到這了,希望我們推薦的答案對大家有所幫助,






