Hibernate Unkown Entity Exception с помощью @MappedSuperClass и Dropwizard - PullRequest
0 голосов
/ 09 января 2019

есть исключение, от которого я не могу избавиться.

У меня есть сущность:

package mypackage.entities;

import javax.persistence.Entity;
import javax.persistence.Table;

@Entity
@Table(name = "raw_air_pressure")
public class RawAirPressureData extends RawSensorData {

    @Override
    public String toString() {
        [...]
    }
}

со своим суперклассом:

package mypackage.entities;

import javax.persistence.Column;
import javax.persistence.MappedSuperclass;
import javax.validation.constraints.NotNull;

@MappedSuperclass
public abstract class RawSensorData extends BaseSensorData {

    @Column(name = "timestamp")
    @NotNull
    private Long timestamp;

    public Long getTimestamp() {
        return timestamp;
    }

    public void setTimestamp(Long timestamp) {
        this.timestamp = timestamp;
    }

    @Override
    public int hashCode() {
        [...]
    }

    @Override
    public boolean equals(Object obj) {
        [...]
    }
}

со своим суперклассом:

package mypackage.entities;

import java.util.Date;

import javax.persistence.Column;
import javax.persistence.GeneratedValue;
import javax.persistence.GenerationType;
import javax.persistence.Id;
import javax.persistence.MappedSuperclass;
import javax.persistence.SequenceGenerator;
import javax.persistence.Temporal;
import javax.persistence.TemporalType;
import javax.validation.constraints.NotNull;

import org.hibernate.annotations.CreationTimestamp;
import org.hibernate.annotations.UpdateTimestamp;

@MappedSuperclass
public abstract class BaseSensorData {

    @Id
    @SequenceGenerator(name = "my_seq", sequenceName = "my_seq", allocationSize = 1)
    @GeneratedValue(strategy=GenerationType.SEQUENCE, generator="my_seq")
    @Column(name = "id")
    private Integer id;

    @Column(name = "value")
    @NotNull
    private Float value;

    @CreationTimestamp
    @Column(name = "created")
    @Temporal(TemporalType.TIMESTAMP)
    private Date created;

    @UpdateTimestamp
    @Column(name = "updated")
    @Temporal(TemporalType.TIMESTAMP)
    private Date updated;

    public Integer getId() {
        return id;
    }

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

    public Float getValue() {
        return value;
    }

    public void setValue(Float value) {
        this.value = value;
    }

    public Date getCreated() {
        return created;
    }

    public void setCreated(Date created) {
        if(created != null) {
            this.created = created;
        }
    }

    public Date getUpdated() {
        return updated;
    }

    public void setUpdated(Date updated) {
        if(updated != null) {
            this.updated = updated;
        }
    }

    @Override
    public int hashCode() {
        [...]
    }

    @Override
    public boolean equals(Object obj) {
        [...]
    }   
}

Сущность зарегистрирована для спящего режима (стиль dropwizard):

private static final HibernateBundle<MyServerConfiguration> hibernate = new HibernateBundle<MyServerConfiguration>(
    MyEntity1.class, MyEntity2.class, [...],
    RawAirPressureData.class) {

@Override
    public DataSourceFactory getDataSourceFactory(MyServerConfiguration configuration) {
        return configuration.getDataSourceFactory();
    }
};

При выполнении этого JUnit:

@Test
    public void testRawAirPressureData() {
        RawAirPressureData myData = TestUtils.generateTestRawAirPressureData();

        RawAirPressureData testMyData = database.inTransaction(() -> {
            return rawAirPressureDataDAO.persist(myData );
        });
[...]

Я получаю это исключение:

org.hibernate.MappingException: неизвестный объект: mypackage.entities.RawAirPressureData at org.hibernate.metamodel.internal.MetamodelImpl.entityPersister (MetamodelImpl.java:620) в org.hibernate.internal.SessionImpl.getEntityPersister (SessionImpl.java:1635) в org.hibernate.engine.internal.ForeignKeys.isTransient (ForeignKeys.java:225) в org.hibernate.event.internal.AbstractSaveEventListener.getEntityState (AbstractSaveEventListener.java:499) в org.hibernate.event.internal.DefaultSaveOrUpdateEventListener.performSaveOrUpdate (DefaultSaveOrUpdateEventListener.java:83) в org.hibernate.event.internal.DefaultSaveOrUpdateEventListener.onSaveOrUpdate (DefaultSaveOrUpdateEventListener.java:73) в org.hibernate.internal.SessionImpl.fireSaveOrUpdate (SessionImpl.java:660) в org.hibernate.internal.SessionImpl.saveOrUpdate (SessionImpl.java:652) в org.hibernate.internal.SessionImpl.saveOrUpdate (SessionImpl.java:647) на io.dropwizard.hibernate.AbstractDAO.persist (AbstractDAO.java:202) в mypackage.db.BaseSensorDataDAO.persist (BaseSensorDataDAO.java:33) в mypackage.db.BaseSensorDataDAOTest.lambda $ testRawAirPressureData $ 6 (BaseSensorDataDAOTest.java:196)

Все предыдущие объекты работают нормально. Но ни один из них не состоит из сопоставленного суперкласса. Я не понимаю, что здесь происходит не так.

Любая помощь будет благодарна.

1 Ответ

0 голосов
/ 10 января 2019

Проблема заключалась в том, что в модульном тесте был создан набор данных с указанием идентификатора, хотя последовательность будет использоваться. Из-за этого кажется, что он сначала сохраняет запись с заданным идентификатором, а затем пытается перезаписать ее в последовательности, которая привела к optimisitcLockException.

После удаления набора идентификаторов в тестовых данных последовательность вышла на свободу и сработала.

...