SpringBoot JPA postgresql.util.PSQLException: 不良的类型值 long

这里写自定义目录标题

    • 问题描述:
    • 问题分析
    • 问题解决
      • 参考的连接:

问题描述:

SpringBoot JPA postgresql.util.PSQLException: 不良的类型值 long_第1张图片
运行时报错org.postgresql.util.PSQLException: 不良的类型值 long
SpringBoot JPA postgresql.util.PSQLException: 不良的类型值 long_第2张图片

问题分析

如图,利用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

你可能感兴趣的:(postgresql,spring,boot,hibernate)