如何在MongoDB中的Spring数据中使用动态模式?
Mongodb是一个无模式文档数据库,但是在春季数据中,有必要定义实体类和存储库类,如下所示:
实体类:
@Document(collection = "users")public class User implements UserDetails {
@Id private String userId;
@NotNull @Indexed(unique = true) private String username;
@NotNull private String password;
@NotNull private String name;
@NotNull private String email;
}
存储库类:
public interface UserRepository extends MongoRepository<User, String> { User findByUsername(String username);
}
无论如何,在春季数据mongodb中是否有使用map not class的功能,以便服务器可以接受任何动态JSON数据,然后将其存储在BSON中而无需任何预定义类?
回答:
您可能想知道,Spring或Java是否是解决您问题的正确解决方案-为什么不使用更动态的工具,例如Ruby,Python或Mongoshell?
话虽这么说,让我们专注于技术问题。
如果您的目标只是存储随机数据,则基本上可以定义自己的控制器并直接使用MongoDB Java驱动程序。
如果您确实坚持为域对象类没有预定义的架构,请使用以下命令:
@Document(collection = "users")public class User implements UserDetails {
@Id
private String id;
private Map<String, Object> schemalessData;
// getters/setters omitted
}
基本上,它为您提供了一个容器,您可以在其中放置所需的任何内容,但要注意序列化/反序列化问题(如果嵌套文档中有ObjectId和DBRef,则可能会很棘手)。另外,如果您的数据层次结构变得过于复杂,则更新数据可能会变得令人讨厌。
仍然,在某个时候,您将意识到您的数据确实具有可以精确定位并放入定义明确的POJO中的模式。
更新资料
由于人们仍然碰巧在2020年仍会阅读此文章,所以进行了最新更新:Jackson注释JsonAnyGetter和JsonAnySetter使您可以隐藏无模式数据容器的根,以便您可以将未知字段作为有效负载中的顶级字段发送。它们仍将嵌套存储在您的MongoDB文档中,但是当通过Spring请求资源时,它们将显示为顶级字段。
@Document(collection = "users")public class User implements UserDetails {
@Id
private String id;
// add all other expected fields (getters/setters omitted)
private String foo;
private String bar;
// a container for all unexpected fields
private Map<String, Object> schemalessData;
@JsonAnySetter
public void add(String key, Object value) {
if (null == schemalessData) {
schemalessData = new HashMap<>();
}
schemalessData.put(key, value);
}
@JsonAnyGetter
public Map<String, Object> get() {
return schemalessData;
}
// getters/setters omitted
}
以上是 如何在MongoDB中的Spring数据中使用动态模式? 的全部内容, 来源链接: utcz.com/qa/414114.html