java – Spring Mongo DB @DBREF

前端之家收集整理的这篇文章主要介绍了java – Spring Mongo DB @DBREF前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

这是我的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

猜你在找的Spring相关文章