问题描述:
运行时报错org.postgresql.util.PSQLException: 不良的类型值 long
问题分析
如图,利用JPA, 从postgresql中导入表生成实体。 其中因为部分字段为text或者varchar[]类型的,因此读取BLOB(即BYTEA)类型数据时出的错,具体是把想byte[]当作long来读取。在另一篇随笔《JPA/Hibernate移植到PostgreSQL时关于CLOB, BLOB及JSON类型的处理》中,解释了PostgreSQL在处理LOB数据的两种方式:oid + bigobject方式和二进制数组方式。
网上大部分解决方案都是重写
org.hibernate.dialect.PostgreSQLxxDialect的getSqlTypeDescriptorOverride()方法, 把ClobTypeDescriptor.CLOB_BINDING 改成ClobTypeDescriptor.STREAM_BINDING 。 太复杂了。
后来发现,是因为注解的问题注解为LOB的时候,会尝试把字符串当做Long类型读取,问题存在于Postgres 和Hibernate 集成的项目中, 可以通过其他的注解来解决问题。
问题解决
删除@Lob注解, 修改为 @Column(name = “alert_name”, columnDefinition=“CLOB”) 类似如此,便可以解决这个问题。
或者 用在@Lob下增加一行注解@Type(type = “org.hibernate.type.TextType”) 来声明具体的类型。
参考的连接:
https://stackoverflow.com/questions/12647755/bad-value-for-type-long-postgresql-hibernate-spring