JPA: столбцы, сгенерированные базой данных - PullRequest
6 голосов
/ 06 мая 2010

У меня проблема с Hibernate и JPA. Мое требование - столбцы CreatedDTTM и LastUPDATEDDTTM должны быть заполнены на уровне БД. Я пытался следовать, но бесполезно. Мои столбцы установлены НЕ NULL. Я получаю исключение «не могу вставить Null в LastUpdatedDttm». Любое руководство приветствуется.

@Column(name="LAST_UPDATED_DTTM", insertable=false, updatable=false, columnDefinition="Date default SYSDATE") 
@org.hibernate.annotations.Generated(value=GenerationTime.INSERT) 
@Temporal(javax.persistence.TemporalType.DATE) 
private Date lastUpdDTTM; 

@Column(name="CREATED_DTTM”, insertable=false, updatable=false) 
@org.hibernate.annotations.Generated(value=GenerationTime.ALWAYS) 
@Temporal(javax.persistence.TemporalType.DATE) 
private Date createdDTTM;

1 Ответ

7 голосов
/ 06 мая 2010

Невозможно воспроизвести. Я тестировал следующую сущность на Derby:

@Entity
public class EntityWithGeneratedField {

    @Id
    @GeneratedValue
    private Long id;

    @Column(name = "LAST_UPDATED_DTTM", insertable = false, updatable = false,
            columnDefinition = "Date default CURRENT_DATE")
    @org.hibernate.annotations.Generated(value = GenerationTime.INSERT)
    @Temporal(javax.persistence.TemporalType.DATE)
    private Date lastUpdDTTM;

    // getters, setters
}

И следующий метод испытаний проходит:

@Test
public void testDateGenerationWhenInsertingEntityWithNullDate() {
    EntityWithGeneratedField e = new EntityWithGeneratedField();
    session.persist(e);
    session.flush();
    assertNotNull(e.getId());
    assertNotNull(e.getLastUpdDTTM());
}

Ниже сгенерированный SQL:

Hibernate: insert into EntityWithGeneratedField (id) values (?)
Hibernate: select entitywith_.LAST_UPDATED_DTTM as LAST2_83_ from EntityWithGeneratedField entitywith_ where entitywith_.id=?

Все работает как положено.

Мой совет: проверьте DDL таблицы, убедитесь, что все работает с необработанным SQL INSERT. Я подозреваю, что проблема на уровне базы данных, а не на уровне Hibernate.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...