Mysql
 sql >> Base de données >  >> RDS >> Mysql

Comment mapper un horodatage d'hibernation sur un MySQL BIGINT ?

Pensez également à créer une implémentation de type Hibernate personnalisée. Quelque chose dans le sens de (psuedocode car je n'ai pas d'environnement pratique pour le rendre à l'épreuve des balles):

public class CalendarBigIntType extends org.hibernate.type.CalendarType {
    public Object get(ResultSet rs, String name) {
        return cal = new GregorianCalendar(rs.getLong(name));
    }
    public void set(PreparedStatement stmt, Object value, int index) {
        stmt.setParameter(index, ((Calendar) value).getTime());
    }
}

Ensuite, vous devrez mapper votre nouvel objet à l'aide d'une mise en veille prolongée des mappages TypeDef et Type. Si vous utilisez des annotations Hibernate, faites comme suit :

@TypeDef (name="bigIntCalendar", typeClass=CalendarBigIntType.class)
@Entity
public class MyEntity {
    @Type(type="bigIntCalendar")
    private Calendar myDate;
}