为什么我在查询实体时没有从 MongoOperation 获得任何结果?

Why do I not get any results from MongoOperation when querying for an entity?

当我执行对数据库的请求时

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 return 一个 null 空而不是序列化 Java 对象?

默认情况下,为给定类型查询的集合派生自您要读取的域类型的简单名称。在您的情况下,那将是 mongoUser。为了让你的例子工作,你基本上有两个选择:

  1. MongoUser 上的 @Document 注释中的 collectionName 显式配置为 users。这基本上会将那个 class 的实例绑定到那个集合,并让那个 class 的所有数据访问操作与那个集合一起工作(例如,对于存储库等)。
  2. 调用 MongoTemplate 时,使用带有显式集合名称的 findOne(…) 的重载:

    template.findOne(query(…), MongoUser.class, "users");