如果您有兴趣,这里有一些代码片段可以获取Hibernate自定义用户类型。首先扩展PostgreSQL方言以告诉它json类型,感谢Craig Ringer JAVA_OBJECT指针:
import org.hibernate.dialect.PostgreSQL9Dialect;
import java.sql.Types;
public class JsonPostgreSQLDialect extends PostgreSQL9Dialect {
public JsonPostgreSQLDialect() {
super();
this.registerColumnType(Types.JAVA_OBJECT, "json");
}
}
接下来实现 org.hibernate.usertype.UserType.下面的实现将 String 值映射到 json 数据库类型,反之亦然。请记住,字符串在 Java 中是不可变的。可以使用更复杂的实现将自定义Java Bean映射到存储在数据库中的JSON。
package foo;
import org.hibernate.HibernateException;
import org.hibernate.engine.spi.SessionImplementor;
import org.hibernate.usertype.UserType;
import java.io.Serializable;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Types;
public class StringJsonUserType implements UserType {
@Override
public int[] sqlTypes() {
return new int[] { Types.JAVA_OBJECT};
}
@Override
public Class returnedClass() {
return String.class;
}
@Override
public boolean equals(Object x, Object y) throws HibernateException {
if( x== null){
return y== null;
}
return x.equals( y);
}
@Override
public int hashCode(Object x) throws HibernateException {
return x.hashCode();
}
@Override
public Object nullSafeGet(ResultSet rs, String[] names, SessionImplementor session, Object owner) throws HibernateException, SQLException {
if(rs.getString(names[0]) == null){
return null;
}
return rs.getString(names[0]);
}
@Override
public void nullSafeSet(PreparedStatement st, Object value, int index, SessionImplementor session) throws HibernateException, SQLException {
if (value == null) {
st.setNull(index, Types.OTHER);
return;
}
st.setObject(index, value, Types.OTHER);
}
@Override
public Object deepCopy(Object value) throws HibernateException {
return value;
}
@Override
public boolean isMutable() {
return true;
}
@Override
public Serializable disassemble(Object value) throws HibernateException {
return (String)this.deepCopy( value);
}
@Override
public Object assemble(Serializable cached, Object owner) throws HibernateException {
return this.deepCopy( cached);
}
@Override
public Object replace(Object original, Object target, Object owner) throws HibernateException {
return original;
}
}
现在剩下的就是注释实体。在实体的类声明中放置类似下面的内容:
@TypeDefs( {@TypeDef( name= "StringJsonObject", typeClass = StringJsonUserType.class)})
然后对属性进行批注:
@Type(type = "StringJsonObject")
public String getBar() {
return bar;
}
Hibernate 将负责为您创建具有 json 类型的列,并处理来回映射。将其他库注入到用户类型实现中,以实现更高级的映射。
这里有一个快速示例GitHub项目,如果有人想玩它:
https://github.com/timfulmer/hibernate-postgres-jsontype