Невозможно воспроизвести. Я тестировал следующую сущность на 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.