Rav*_*eja 3 java spring mongodb
嗨,我有我的第一个收藏
students
{
"name" : "abc"
"class" : "1"
"subjects" : DBRef("subjects","class1")
}
Run Code Online (Sandbox Code Playgroud)
和我的第二个系列
subjects
{
"_id" : "class1"
"sub1" : "english"
"sub2" : "physics"
}
Run Code Online (Sandbox Code Playgroud)
我希望在加入上述两个集合之后实现我的输出
{
"name" : "abc"
"class" : "1"
"subjects" : {sub1 : "english",sub2 : "physics"}
}
Run Code Online (Sandbox Code Playgroud)
有可能,如果是的话怎么样?
您可以使用@DBRef从中引用Subjects文档Student.
映射框架不必存储嵌入在文档中的子对象.您也可以单独存储它们并使用DBRef来引用该文档.当从MongoDB加载对象时,将急切地解析这些引用,并且您将获得一个映射对象,该对象看起来与嵌入在主文档中的对象相同.
下面是一个使用DBRef引用特定文档的示例,该文档独立于引用它的对象而存在(为了简洁起见,这两个类都以内联方式显示):
编辑:-
实际上,为了给你更多细节,@DBRef注释会急切地加载数据(即本例中的主题).
学生模特课: -
@Document(collection = "students")
public class Students implements Serializable, BaseDocument {
private static final long serialVersionUID = -3534650012619938612L;
@Id
private String id;
@Field("class")
private String className;
@DBRef
@Field("subjects")
private Subject subject;
public String getId() {
return id;
}
public String getClassName() {
return className;
}
public void setId(String id) {
this.id = id;
}
public void setClassName(String className) {
this.className = className;
}
public Subject getSubject() {
return subject;
}
public void setSubject(Subject subject) {
this.subject = subject;
}
@Override
public String toString() {
return "Students [id=" + id + ", className=" + className + ", subject=" + subject + "]";
}
}
Run Code Online (Sandbox Code Playgroud)
科目类型: -
@Document(collection = "subjects")
public class Subject implements Serializable, BaseDocument {
private static final long serialVersionUID = -3534650012619938612L;
@Id
private String id;
private String sub1;
private String sub2;
public String getId() {
return id;
}
public String getSub1() {
return sub1;
}
public String getSub2() {
return sub2;
}
public void setId(String id) {
this.id = id;
}
public void setSub1(String sub1) {
this.sub1 = sub1;
}
public void setSub2(String sub2) {
this.sub2 = sub2;
}
@Override
public String toString() {
return "Subject [id=" + id + ", sub1=" + sub1 + ", sub2=" + sub2 + "]";
}
}
Run Code Online (Sandbox Code Playgroud)
按身份获取学生: -
当您通过Id获得学生时,框架/ mongodb将自动加载主题数据.您无需专门进行连接即可获取主题数据.
public Students getStudents(String id) {
MongoOperations mongoOperations = getMongoConnection();
Students students = mongoOperations.findById(id, Students.class);
System.out.println(students.toString());
return students;
}
Run Code Online (Sandbox Code Playgroud)
输出: -
Students [id=584ea66e9e53b7802651de36, className=1, subject=Subject [id=class1, sub1=english, sub2=physics]]
Run Code Online (Sandbox Code Playgroud)
科目集: -
{
"_id" : "class1",
"sub1" : "english",
"sub2" : "physics"
}
Run Code Online (Sandbox Code Playgroud)
学生收藏: -
{
"_id" : ObjectId("584ea66e9e53b7802651de36"),
"name" : "abc",
"class" : "1",
"subjects" : {
"$ref" : "subjects",
"$id" : "class1",
"$db" : "localhost"
}
}
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
6899 次 |
| 最近记录: |