0

我在 MongoDB 中使用 Hibernate OGM (5.0.3.Final)。我用 strategy=InheritanceType.SINGLE_TABLE 保留了这个复合结构。当我尝试查询 TextNode 时,我发现属性“文本”为空,但如果我使用 mongo shell 检查数据库,我可以看到属性文本不为空。这里是数据库。我报告了我在下面使用的代码。

节点类:

@Entity
@Inheritance( strategy=InheritanceType.SINGLE_TABLE )

public abstract class Node {

private Set<NodeLink> children;

private String id;
private String name;

public Node(){
    children = new HashSet<>();
}

@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
@Type(type = "objectid")
public String getId() {
    return id;
}

public void setId(String id) {
    this.id = id;
}

public void setName(String name) {
    this.name = name;
}

public String getName() {
    return name;
}


@OneToMany( mappedBy="source" )
public Set<NodeLink> getChildren() {
    return children;
}
void setChildren(Set<NodeLink> children) {
    this.children = children;
}

}

节点链接类:

@Entity
public class NodeLink {

private String id;

private Node source;
private Node target;


@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
@Type(type = "objectid")
public String getId() {
    return id;
}
public void setId(String id) {
    this.id = id;
}

@ManyToOne
public Node getSource() {
    return source;
}
void setSource(Node source) {
    this.source = source;
}
public void assignSource(Node source) {
    setSource(source);
    source.getChildren().add(this);
}

@ManyToOne
public Node getTarget() {
    return target;
}
void setTarget(Node target) {
    this.target = target;
}
public void assignTarget(Node target) {
    setTarget(target);
}

}

简单节点类:

@Entity
public class SimpleNode extends Node {

public SimpleNode() {
    super();
}
}

文本节点类:

@Entity
public class TextNode extends Node {

private String text;

public TextNode() {
    super();
}

public String getText() {
    return text;
}
public void setText(String text) {
    this.text = text;
}

}

主类:

public class MainNode {
private static EntityManagerFactory ENTITY_MANAGER_FACTORY;
private static EntityManager manager;

public static void main(String[] args) {
    ENTITY_MANAGER_FACTORY = Persistence.createEntityManagerFactory("JavaHelps");
    manager = ENTITY_MANAGER_FACTORY.createEntityManager();

    createDB();
    queryDB();
}

//
// CREATE DB
//

private static void createDB() {
    EntityTransaction transaction1 = manager.getTransaction();
    transaction1.begin();

    Node root1 = new SimpleNode();
    root1.setName("root");
    Node child1 = new SimpleNode();
    child1.setName("children1");
    TextNode child2 = new TextNode();
    child2.setName("children2");
    child2.setText("a text");

    NodeLink nl4=new NodeLink();
    nl4.assignSource(root1);
    nl4.assignTarget(child1);

    NodeLink nl3=new NodeLink();
    nl3.assignSource(root1);
    nl3.assignTarget(child2);

    manager.persist(root1);
    manager.persist(child1);
    manager.persist(child2);
    manager.persist(nl4);
    manager.persist(nl3);

    transaction1.commit();
}


//
// QUERY DB
//

@SuppressWarnings("unchecked")
private static void queryDB() {
"db.Node.find({'type_id':"+"ObjectId('"+typeId+"')})";
    Node node = manager.find(SimpleNode.class,    "5832c8762fc11706a29125b5");
    print(node);
}

private static void print(Node n) {
    System.out.println(n.getClass().getSimpleName() + " : " + n.getName() + " : " + (n.getClass().getSimpleName().equals("TextNode")? ((TextNode)n).getText() : "") );
    for(NodeLink c : n.getChildren()) {
        print(c.getTarget());
    }
}

}

我的问题是:我在 Hibernate OGM 中发现错误,或者我的代码中有错误?谢谢。

4

0 回答 0