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

问题描述:

在这里插入图片描述
运行时报错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

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值