Nag*_*gyI 5 java postgresql persistence
我喜欢ltree在我的一个项目中使用PostgreSQL contrib,我喜欢在数据库之上使用某种ORM层(Hibernate,EclipseLink).我没有找到任何有关使用此类型与持久性有用的东西.我想我必须使用新类型和相应的运算符扩展当前的PostgreSQL方言.但是,我真的不知道从哪里开始,以及正确的方法是什么.ltree非常像一个字符串,所以我猜我应该从字符串表示开始.
有人可以给我建议和/或链接到做类似事情的例子吗?我还没找到完整的教程.
这个:
@Column(name = "dir", nullable = false, columnDefinition = "ltree")
@Type(type = "ru.zen0n.hibernate.types.LTreeType")
private String path;
Run Code Online (Sandbox Code Playgroud)
还有这个:
package ru.zen0n.hibernate.types;
import java.io.Serializable;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Types;
import org.hibernate.HibernateException;
import org.hibernate.usertype.UserType;
public class LTreeType implements UserType {
@Override
public int[] sqlTypes() {
return new int[] {Types.OTHER};
}
@SuppressWarnings("rawtypes")
@Override
public Class returnedClass() {
return String.class;
}
@Override
public boolean equals(Object x, Object y) throws HibernateException {
return x.equals(y);
}
@Override
public int hashCode(Object x) throws HibernateException {
return x.hashCode();
}
@Override
public Object nullSafeGet(ResultSet rs, String[] names, Object owner)
throws HibernateException, SQLException {
return rs.getString(names[0]);
}
@Override
public void nullSafeSet(PreparedStatement st, Object value, int index)
throws HibernateException, SQLException {
st.setObject(index, value, Types.OTHER);
}
@Override
public Object deepCopy(Object value) throws HibernateException {
return new String((String)value);
}
@Override
public boolean isMutable() {
return false;
}
@Override
public Serializable disassemble(Object value) throws HibernateException {
return (Serializable)value;
}
@Override
public Object assemble(Serializable cached, Object owner)
throws HibernateException {
return cached;
}
@Override
public Object replace(Object original, Object target, Object owner)
throws HibernateException {
// TODO Auto-generated method stub
return deepCopy(original);
}
}
Run Code Online (Sandbox Code Playgroud)
这里有一些可能对您有帮助的提示。这不是一个完整的答案,但对于评论来说有点太多了。
Hibernate 和 EclipseLink 都实现了 JPA 标准,但也有一些自己的扩展,并允许自定义行为。
我还没有对 ltree 进行任何具体的工作,但我认为您可以只使用 java String 类并向列添加注释来推翻所使用的正常列类型(这可以在标准 JPA 中完成)。
@Column(columnDefinition="ltree")
private String myLtreeValue;
Run Code Online (Sandbox Code Playgroud)
如果 Java 端的 String 还不够,您可以创建自己的类并为其编写转换器类。您可以在这个问题中看到一个例子。这将取决于持久性提供者。
当使用涉及 ltree 值的条件执行查询时,最好使用 JPA @NamedNativeQuery 注释来定义涉及特殊运算符的查询。示例请参见此处
| 归档时间: |
|
| 查看次数: |
2226 次 |
| 最近记录: |