现象:Hibernate自动生成数据库表,发现使用@Lob注解后postgresql对应字段类型为oid(错误类型,应该生成text类型),oracle数据库生成字段类型为CLOB(正常数据类型);
尝试解决方法一:在@Column注解中设置columnDefinition = "text",结果postgresql问题解决了,但是oracle数据库中没有text数据类型;
尝试解决方法二:在getContent()方法上添加@Type(type = "org.hibernate.type.TextType"),结果postgresql问题解决了,但是oracle生成的字段类型为LONG,而不是 CLOB;
最终尝试:自己写一个类MyType实现org.hibernate.usertype.UserType,重写sqlTypes()方法如下所示:
@Override public int[] sqlTypes() { Properties properties= PropertiesUtil.getInstance().getProperties(MyPropertiesManager.MY_PATH); String property = properties.getProperty(MyPropertiesManager.DB_DRIVER); String dialect = property.toLowerCase(); //Table.DB_TYPE_ORACLE = "oracle" if (dialect.contains(Table.DB_TYPE_ORACLE)) { return new int[]{Types.CLOB}; }else{ return new int[]{Types.LONGVARCHAR}; } }
最后将类型加到getContent()方法上
@Lob @Column(name = "content") @Type(type="com.ybm.dongzhou.common.MyType") public String getContent() { return content; }
完美解决了hibernate生成postgresql及oracle数据库表问题