Подтвердить что ты не робот

У вас есть общий базовый класс для объектов Hibernate?

Есть ли у вас общий базовый класс для объектов Hibernate, т.е. MappedSuperclass с идентификатором, версией и другими общими свойствами? Есть ли недостатки?

Пример:

@MappedSuperclass()
public class BaseEntity {

    private Long id;
    private Long version;
    ...

    @Id @GeneratedValue(strategy = GenerationType.AUTO)
    public Long getId() {return id;}

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

    @Version
    public Long getVersion() {return version;}
    ...

    // Common properties
    @Temporal(TemporalType.TIMESTAMP)
    public Date creationDate() {return creationDate;}
    ...
}

@Entity
public class Customer extends BaseEntity {
    private String customerName;
    ...
}
4b9b3361

Ответ 1

Это отлично работает для нас. Помимо даты и даты создания, мы также имеем модифицированную дату. У нас также есть промежуточная TaggedBaseEntity, которая реализует интерфейс Taggable, потому что у некоторых наших сущностей веб-приложений есть теги, например вопросы в Stack Overflow.

Ответ 2

Тот, который я использую, прежде всего, реализует hashCode() и equals(). Я также добавил метод для точной печати объекта. В ответ на DR выше, большая часть этого может быть переопределена, но в моей реализации вы застряли с идентификатором типа Long.

public abstract class BaseEntity implements Serializable {

    public abstract Long getId();
    public abstract void setId(Long id);

    /**
     * @see java.lang.Object#hashCode()
     */
    @Override
    public int hashCode() {
        final int prime = 31;
        int result = 1;
        result = prime * result + ((getId() == null) ? 0 : getId().hashCode());
        return result;
    }

    /**
     * @see java.lang.Object#equals(Object)
     */
    @Override
    public boolean equals(Object obj) {
        if (this == obj)
            return true;
        if (obj == null)
            return false;
        if (getClass() != obj.getClass())
            return false;
        BaseEntity other = (BaseEntity) obj;
        if (getId() == null) {
            if (other.getId() != null)
                return false;
        } else if (!getId().equals(other.getId()))
            return false;
        return true;
    }

    /**
     * @see java.lang.Object#toString()
     */
    @Override
    public String toString() {
        return new StringBuilder(getClass().getSimpleName()).append(":").append(getId()).toString();
    }

    /**
     * Prints complete information by calling all public getters on the entity.
     */
    public String print() {

        final String EQUALS = "=";
        final String DELIMITER = ", ";
        final String ENTITY_FORMAT = "(id={0})";

        StringBuffer sb = new StringBuffer("{");

        PropertyDescriptor[] properties = PropertyUtils.getPropertyDescriptors(this);
        PropertyDescriptor property = null;
        int i = 0;
        while ( i < properties.length) {

            property = properties[i];
            sb.append(property.getName());
            sb.append(EQUALS);

            try {
                Object value = PropertyUtils.getProperty(this, property.getName());
                if (value instanceof BaseEntity) {
                    BaseEntity entityValue = (BaseEntity) value;
                    String objectValueString = MessageFormat.format(ENTITY_FORMAT, entityValue.getId());
                    sb.append(objectValueString);
                } else {
                    sb.append(value);
                }
            } catch (IllegalAccessException e) {
                // do nothing
            } catch (InvocationTargetException e) {
                // do nothing
            } catch (NoSuchMethodException e) {
                // do nothing
            }

            i++;
            if (i < properties.length) {
                sb.append(DELIMITER);
            }
        }

        sb.append("}");

        return sb.toString();
    }
}

Ответ 3

Я бы без колебаний использовал общий базовый класс, после всего, что точка O/R-отображения.

Я также использую общие базовые классы, но только если сущности разделяют хотя бы некоторые общие свойства. Я не буду использовать его, если идентификатор является единственным общим свойством. До сих пор я не сталкивался с какими-либо проблемами.

Ответ 4

Это хорошо работает и для меня.

Обратите внимание, что вы также можете в этой сущности добавить некоторые прослушиватели/перехватчики событий, такие как Hibernate Envers, один или любой пользовательский, в соответствии с вашими потребностями, чтобы вы могли: - Отслеживать все изменения - Знайте, какой пользователь произвел последнюю модификацию - автоматически обновлять последнюю модификацию - Автоматическая установка первой даты вставки И все такое...