这是我的MongoDb结构,
db.user.find();
用户:
{
"name" : "KSK","claim" : [objectId("52ffc4a5d85242602e000000"),objectId("52ffc4a5d85242602e000001")]
}
要求:
[
{
"_id" : "52ffc4a5d85242602e000001","claimName" :"XXXX"
},{
"_id" : "52ffc4a5d85242602e000000","claimName" :"YYY"
}
]
我的实体类是:
@Document(collection="user")
public class User{
@Id
private String id;
private String name;
@DBRef
private List
索赔等级:
@Document(collection="Claim")
public class Claim{
@Id
private String id;
private String claimName;
}
public User findByName(String name);
没有找到能够从类型org.bson.types.ObjectId转换为类型java.lang.String的转换器
所以我改变了我的User实体类,
而不是私人列表<索赔>要求;
已更改为私人列表< ObjectId>要求;
现在,如果我执行一个方法(findByName),我得到一个同时具有声明对象ID(“52ffc4a5d85242602e000001”,“52ffc4a5d85242602e000000”)的用户对象,然后迭代声明列表并获取与声明对象Id相对应的声明详细信息.
最佳答案
如果您使用@DBRef在User类中引用您的声明,那么您的JSON不仅应该包含ID,还应该包含对集合的引用以及在何处查找ID,如下所示:
{
"name" : "KSK","claim" : [
{ "$ref":"claim",// the target collection
"$id : "ObjectId("52ffc4a5d85242602e000000")
}
]
}
这就是Spring-Data将您的Java对象映射到MongoDB的方式.如果你从一个空白数据库开始,让Spring创建并保存关系,你应该没有问题
@DBRef List