ObjectDB, не удалось записать значение поля (ошибка 363) - PullRequest
1 голос
/ 20 января 2012

Я пытаюсь создать приложение, которое может хранить древовидную структуру с файлами и папками в базе данных ObjectDB (embedde), но даже с помощью простого теста я получаю сообщение об ошибке ...

Классы сущностей

Node.java

@MappedSuperclass
public abstract class Node {

    @Column(name = "Name", nullable = false)
    private String name;

    @Column(name = "Parent_FK")
    @ManyToOne(fetch = FetchType.LAZY)
    @JoinColumn(name = "FolderID", nullable = true)
    private FolderNode parent = null;

    public Node() {
    }

    public Node(String name) {
        this.name = name;
    }

    public String getName() {
        return name;
    }

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

    public boolean hasParent() {
        return (parent != null);
    }

    public FolderNode getParent() {
        return parent;
    }

    void setParent(FolderNode parent) {
        this.parent = parent;
    }

    @Override
    public int hashCode() {
        return new HashCodeBuilder(17, 31).append(name).toHashCode();
    }

    @Override
    public boolean equals(Object obj) {
        if (obj == null) {
            return false;
        }
        if (obj == this) {
            return true;
        }
        if (obj instanceof Label) { // TODO is instanceof enough??
            Label other = (Label) obj;
            return name.equals(other.getName());
        }
        return false;
    }
}

FolderNode.java

@Entity(name = "Folders")
public class FolderNode extends Node {

    @Column(name = "FolderID")
    @Id
    @GeneratedValue(strategy = GenerationType.AUTO)
    private long id;

    @OneToMany(cascade = CascadeType.ALL, mappedBy = "parent", fetch = FetchType.LAZY, orphanRemoval = true)
    private Set<Node> children = new HashSet<Node>();

    public FolderNode() {
    }

    public FolderNode(String name) {
        super(name);
    }

    public Set<Node> getChildren() {
        return children;
    }

    public void setChildren(Set<Node> children) {
        this.children = children;
    }

    public long getId() {
        return id;
    }

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

Телефонный код

//Init
EntityManagerFactory emf = Persistence.createEntityManagerFactory("database.odb");
EntityManager em = emf.createEntityManager();

//Create object
FolderNode rootFolder = new FolderNode("root");

//Persist
em.getTransaction().begin();
em.persist(rootFolder);
em.getTransaction().commit();

em.close();
emf.close();

emf = Persistence.createEntityManagerFactory("database.odb");
em = emf.createEntityManager();

TypedQuery<FolderNode> query = em.createQuery("SELECT f FROM Folders f", FolderNode.class);
List<FolderNode> result = query.getResultList();

И вот где он падает, за исключением:

[ObjectDB 2.3.5_07] javax.persistence.PersistenceException
Failed to write the value of field field FolderNode.children using reflection (error 363)

Проблема, похоже, исчезнет, ​​если я не закрою и не открою EntityManagerFactory и EntityManager перед извлечением объекта.

Что мне здесь не хватает?

1 Ответ

2 голосов
/ 20 января 2012

Ваш код демонстрирует проблему в обработке отображенных суперклассов.Если вы замените аннотацию @MappedSuperclass на @Entity (для класса Node), ваш тест будет работать хорошо.

ObjectDB должен обрабатывать сопоставленные суперклассы как классы сущностей, поэтому, следуя вашему сообщению, эта проблема была устранена,test (с @MappedSuperclass) должен работать со сборкой 2.3.6_14.

...