[英]Why do I not get any results from MongoOperation when querying for an entity?
当我对db执行请求时
db.users.find({"name": "Max"})
我得到了这个结果
{"_id":ObjectId("5785718ee271a7c7ebaad28b"),"name":"Max","visits-by-day":[{"day":"Thursday","visitsAmount":20},{"day":"Saturday","visitsAmount":4}]}
JSON结构示例:
{
"users": [
{
"name": "Bobby",
"visits-by-day": [
{
"day": "Sunday",
"visitsAmount": 8
},
{
"day": "Monday",
"visitsAmount": 3
}
]
}
]
}
这是我的Java代码
MongoUser user = mongoTemplate.findOne(query(where("name").is("Max")), MongoUser.class);
该模型
@Document
public class MongoUser {
@Id
private String id;
private String name;
private List<VisitsPerDay> visitsByDay;
// Getters & Setters omitted
}
public class VisitsPerDay {
private String day;
private Integer visitsAmount;
// Getters & Setters omitted
}
为什么Spring确实返回null空而不是序列化的Java对象?
默认情况下,查询给定类型的集合是从您要读取的域类型的简单名称派生的。 在你的情况下,那将是mongoUser
。 为了让你的例子有效,你基本上有两个选择:
MongoUser
上的@Document
注释中明确配置collectionName
给users
。 这将基本上将该类的实例绑定到该集合,并让该类的所有数据访问操作与该集合一起使用(例如,对于存储库等)。 调用MongoTemplate
,请使用带有显式集合名称的findOne(…)
重载:
template.findOne(query(…), MongoUser.class, "users");
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.