我在mongodb中使用Spring Data的CrudRepository,并且在编写查询时会遇到一些问题,该查询将选择具有特定子文档值的文档。这是一个例子:
{
"_id" :,
"_class" :,
"matchHeader" : {
"suspend" : {},
"active" : true,
"booked" : true,
"eventId" : NumberLong(1009314492),
"status" : ""
},
"matchInfo" : {
}
}
}
我需要在 matchHeader 子文档中选择具有特定 eventId 字段的文档。我试图编写一个类似于的函数findByMatchHeaderEventId(id),但它完全没有帮助。我如何实现这一点?
最佳答案
嵌套属性的属性遍历在Spring Data MongoDB Reference Documentation中进行了说明。
您需要正确定义域对象类(省略构造函数/获取程序/设置程序):
public class MyDocument {
@Id
private String id;
private MatchHeader matchHeader;
private MatchInfo matchInfo;
...
}
public class MatchHeader {
private Map<,> suspend;
private boolean active;
private boolean booked;
private Long eventId;
private String status;
}
和您的存储库类
public interface MyDocumentController extends MongoRepository<MyDocument, String> {
public List<MyDocument> findByMatchHeaderEventId(Long id);
}
否则,您可以尝试其他答案中建议的findByMatchHeader_EventId。