sql >> Base de Datos >  >> RDS >> Mysql

¿Cómo mapeo una marca de tiempo de hibernación a MySQL BIGINT?

Además, observe la creación de una implementación personalizada de Hibernate Type. Algo similar a (pseudocódigo ya que no tengo un entorno práctico para hacerlo a prueba de balas):

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());
    }
}

Luego, deberá mapear su nuevo objeto utilizando un TypeDef de hibernación y asignaciones de tipo. Si está utilizando anotaciones de Hibernate, sea como sigue:

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