Spring Mongo DB @DBREF

KSK*_*KSK 9 java mongodb spring-mongo spring-mongodb

这是我的MongoDb结构,

db.user.find();
Run Code Online (Sandbox Code Playgroud)

用户:

{
"name" : "KSK", 
 "claim"  : [objectId("52ffc4a5d85242602e000000"),objectId("52ffc4a5d85242602e000001")] 
}
Run Code Online (Sandbox Code Playgroud)

要求:

[
   {
     "_id" : "52ffc4a5d85242602e000001",
     "claimName" :"XXXX"
   },
   {
     "_id" : "52ffc4a5d85242602e000000",
     "claimName" :"YYY"
   }
]
Run Code Online (Sandbox Code Playgroud)

我的实体类是:

@Document(collection="user")
public  class User{
  @Id      
  private String id;
  private String name; 
  @DBRef
private List<Claim> claim; 
// setter and getter 

}
Run Code Online (Sandbox Code Playgroud)

索赔等级:

@Document(collection="Claim")
public class Claim{
   @Id 
   private String id; 
   private String claimName;   
}
Run Code Online (Sandbox Code Playgroud)

我有一个方法来获取用户名,如下所示,

public User findByName(String name);
Run Code Online (Sandbox Code Playgroud)

如果我试图点击这个方法我得到一个错误,

没有找到能够从类型org.bson.types.ObjectId转换为类型java.lang.String的转换器

所以我改变了我的User实体类,如下所示,

而不是 private List<Claim> claim;

改为Private List<ObjectId> claim;

现在,如果我执行一个方法(findByName),我得到一个同时具有声明对象ID("52ffc4a5d85242602e000001","52ffc4a5d85242602e000000")的用户对象,然后迭代声明列表并获取与声明对象Id相对应的声明详细信息.

而不是这样做,当我执行findByName方法时,我想获得一个用户并声明详细信息.我该如何实现此功能

Mat*_*att 14

如果您ClaimUser类中使用@DBRef引用您的s,则您的 JSON 不仅应包含 ID,还应包含对在何处查找 ID 的集合的引用,如下所示:

{
  "name" : "KSK", 
  "claim" : [ 
     { 
       "$ref" : "claim", // the target collection
       "$id" : ObjectId("52ffc4a5d85242602e000000")
     }
  ] 
}
Run Code Online (Sandbox Code Playgroud)

这就是 Spring-Data 将您的 Java 对象映射到MongoDB 的方式。如果您从一个空白数据库开始并让 Spring 创建并保存关系,那么使用它应该没有问题

 @DBRef List<Claim> claims;
Run Code Online (Sandbox Code Playgroud)