带有 Java 外键的 MongoDb

sur*_*esh 2 java spring mongodb spring-data spring-data-mongodb

我需要使用 Java 在我的 MongoDB 中保存两个集合。其中一个集合是Department,另一个集合是Employee。如果一个部门可以有很多员工,我想保存一个集合,例如必须将员工唯一 ID 映射到我的部门员工列表中。

例子:

{
    "_id" : ObjectId("598da19250aa4ad2413d4bc0"),
    "_class" : "com.department",
    "departmentName" : "SAQ-A",
    "departmentNumber" : "3_2",
    "employee" : [ 
           "id" : "1",
           "id" : "2",
           "id" : "3"
     ]
}
Run Code Online (Sandbox Code Playgroud)

我可以知道使用 Java 在 MongoDB 中实现它的方式是什么吗?

mma*_*uga 6

通过提供的文档和标签,我假设您正在使用 spring 数据来处理 mongodb。所以在这里你可能想使用 DBRefs 将员工绑定到部门。幸运的是Spring Data为您提供了 @DBRef 注释。

员工类:

import org.springframework.data.annotation.Id;
import org.springframework.data.mongodb.core.mapping.Document;

@Document
public class Employee {

    @Id
    private Integer id;
    ...

}
Run Code Online (Sandbox Code Playgroud)

科室类:

import org.springframework.data.annotation.Id;
import org.springframework.data.mongodb.core.mapping.DBRef;
import org.springframework.data.mongodb.core.mapping.Document;

@Document
public class Department {

    @Id
    private String id;

    @DBRef
    private Collection<Employee> employees;
    ...
}
Run Code Online (Sandbox Code Playgroud)

MongoDB 文档:

{
    "_id" : ObjectId("598dc04ac4fdd0e29867ccbb"),
    "_class" : "foo.bar.Department",
    "employees" : [ 
        {
            "$ref" : "employee",
            "$id" : 1
        }, 
        {
            "$ref" : "employee",
            "$id" : 2
        }
    ]
}
Run Code Online (Sandbox Code Playgroud)

注意: MongoDB 中必须已经存在 Employee 实例。DBRef 不会以级联方式保存员工。看看这篇关于级联的文章。