PostgreSQL
 sql >> Datenbank >  >> RDS >> PostgreSQL

So ordnen Sie PostgreSQL-Enumerationen JPA und Hibernate zu

Ich habe es herausgefunden. Ich musste setObject anstelle von setString in der nullSafeSet-Funktion verwenden und Types.OTHER als java.sql.type übergeben, um jdbc wissen zu lassen, dass es sich um einen Postgres-Typ handelt.

public void nullSafeSet(PreparedStatement st, Object value, int index) throws HibernateException, SQLException {
    if (value == null) {
        st.setNull(index, Types.VARCHAR);
    }
    else {
//            previously used setString, but this causes postgresql to bark about incompatible types.
//           now using setObject passing in the java type for the postgres enum object
//            st.setString(index,((Enum) value).name());
        st.setObject(index,((Enum) value), Types.OTHER);
    }
}