sql >> Databáze >  >> RDS >> Mysql

Jak namapuji časové razítko hibernace na MySQL BIGINT?

Podívejte se také na vytvoření vlastní implementace Hibernate Type. Něco ve smyslu (psuedocode, protože nemám praktické prostředí, aby to bylo neprůstřelné):

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

Poté budete muset svůj nový objekt namapovat pomocí mapování typu hibernace TypeDef a Type. Pokud používáte anotace Hibernate, postupujte takto:

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


  1. Index generování hibernace a cizí klíč se stejným názvem pro MySQL

  2. Funkce data a času MySQL neexistují

  3. Určete, zda jsou dvě jména blízko sebe

  4. Přesouvání webu Wordpress do Dockeru:Chyba při navazování připojení k databázi