2016-12-16 2 views
2

Я пытаюсь сохранить ZonedDateTime для Oracle. Ниже мой домен класс сущностей:ZonedDateTime с Oracle

@Entity 
@Table(name = "TESTTABLE") 
public class Order { 
    private static final long serialVersionUID = 1L; 

    @Type(type = "uuid-binary") 
    @Column(name = "ID") 
    private UUID id; 

    @Column(name = "CREATE_DATE") 
    private ZonedDateTime createdOn; 

..and so on. 

У меня также есть конвертер следующим образом преобразовать даты:

@Converter(autoApply = true) 
public class OracleZonedDateTimeSeriliazer implements AttributeConverter<ZonedDateTime,Date>{ 


     @Override 
    public Date convertToDatabaseColumn(ZonedDateTime attribute) { 
     return attribute == null ? null : java.util.Date.from(attribute.withZoneSameInstant 
       (ZoneOffset.UTC).toInstant()); 
    } 

    @Override 
    public ZonedDateTime convertToEntityAttribute(Date dbData) { 
     return dbData == null ? null : ZonedDateTime.ofInstant(dbData.toInstant(), DateUtils.getEasternZoneId()); 
    } 
} 

Когда я пытаюсь упорствовать эту сущность я получаю следующую трассировку стека:

2016-12-16 10:47:06,669 [main] ERROR o.h.e.jdbc.spi.SqlExceptionHelper - ORA-00932: inconsistent datatypes: expected DATE got BINARY 
org.springframework.dao.InvalidDataAccessResourceUsageException: could not execute statement; SQL [n/a]; nested exception is org.hibernate.exception.SQLGrammarException: could not execute statement 

Если кто-нибудь может мне помочь, что я делаю неправильно, это было бы очень признательно.

+0

Возможно, вам стоит попробовать преобразовать в 'java.sql.Timestamp' вместо' java.util.Date', учитывая, что 'java.util.Date' не поддерживается JDBC API, поэтому конвертер не вызывается и «ZonedDateTime» сериализуется в байтах как «пользовательский» Java-класс. Разумеется, вы также можете просто включить 'hibernate-java8', см. Http://stackoverflow.com/a/33001846/5221149 – Andreas

+0

Что такое тип столбца DB-CREATE_DATE? –

+1

@MenoHochschild его DATE, который является sql.Date – Gurkha

ответ

1

Добавить @Convert (конвертер = OracleZonedDateTimeSeriliazer.class) поверх атрибута createdOn в классе Entity.

Смежные вопросы