这是我的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相对应的声明详细信息.
而不是这样做,当我执行findByName方法时,我想获得一个用户并声明详细信息.我该如何实现此功能
最佳答案
如果您使用@DBRef在User类中引用您的声明,那么您的JSON不仅应该包含ID,还应该包含对集合的引用以及在何处查找ID,如下所示:
{
"name" : "KSK","claim" : [
{ "$ref":"claim",// the target collection
"$id : "ObjectId("52ffc4a5d85242602e000000")
}
]
}
这就是Spring-Data将您的Java对象映射到MongoDB的方式.如果你从一个空白数据库开始,让Spring创建并保存关系,你应该没有问题
@DBRef List
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。