解决 MyBatis-Plus + PostgreSQL 中的 org.postgresql.util.PSQLException 异常

2023-08-01 17:15:21

🌷🍁 博主猫头虎 带您 Go to New World.✨🍁
🦄 博客首页——猫头虎的博客🎐
🐳《面试题大全专栏》 文章图文并茂🦕生动形象🦖简单易学!欢迎大家来踩踩~🌺
🌊 《IDEA开发秘籍专栏》学会IDEA常用操作,工作效率翻倍~💐
🌊 《100天精通Golang(基础入门篇)》学会Golang语言,畅玩云原生,走遍大小厂~💐

🪁🍁 希望本文能够给您带来一定的帮助🌸文章粗浅,敬请批评指正!🍁🐥

在这里插入图片描述

错误截图:
在这里插入图片描述

引言

在使用 MyBatis-Plus 和 PostgreSQL 数据库时,有时候会遇到 org.postgresql.util.PSQLException 异常,错误信息为 “conversion to class java.time.OffsetDateTime from int4 not supported”。这个异常通常是由于数据库字段类型与实体类属性类型不匹配引起的。本文将介绍如何通过在实体类中添加 @TableField 注解并指定参数来解决这个问题。

问题描述

当使用 MyBatis-Plus 连接 PostgreSQL 数据库时,如果数据库中某个字段的数据类型是 TIMESTAMP,而对应的实体类属性类型是 OffsetDateTime,可能会在查询或插入数据时抛出异常:

org.postgresql.util.PSQLException: ERROR: column "create_time" is of type timestamp without time zone but expression is of type integer
Hint: You will need to rewrite or cast the expression.
Position: xx

org.springframework.dao.DataIntegrityViolationException: Error attempting to get column 'id' from result set.  Cause: org.postgresql.util.PSQLException: conversion to class java.time.OffsetDateTime from int4 not supported
; conversion to class java.time.OffsetDateTime from int4 not supported; nested exception is org.postgresql.util.PSQLException: conversion to class java.time.OffsetDateTime from int4 not supported] with root cause

org.postgresql.util.PSQLException: conversion to class java.time.OffsetDateTime from int4 not supported

解决方案

方向一:
由于在从数据库结果集中尝试获取’ id ‘列时出现类型转换错误。具体来说,数据库中的’ id '列的数据类型是int4(整数),但在映射到Java实体类时,使用了java.time.OffsetDateTime(时间日期)类型,导致转换失败。

  1. 修改Java实体类的数据类型:
    你可以将对应’ id '列的数据类型修改为int或Long类型,以便与数据库的int4类型匹配。例如,在你的Java实体类中,将id字段的数据类型改为Long,而不是OffsetDateTime。这样,你就可以正确地映射数据库的id列数据到Java实体类。

  2. 使用类型转换器:
    如果你需要保持Java实体类中的id字段为OffsetDateTime类型,你可以考虑使用Spring的类型转换器(TypeConverter)或自定义的属性编辑器(PropertyEditor)来处理数据类型转换。这样,你可以在获取数据时,将数据库返回的int值转换为OffsetDateTime类型。这个方法需要编写一些代码,但可以让你在Java实体类中保持OffsetDateTime类型的数据。

方向二:

解决这个异常的方法是通过在实体类中添加 @TableField 注解,并使用 jdbcType 参数来显式指定数据库字段的数据类型。

假设我们有一个名为 User 的实体类,其中有一个字段名为 createTime,数据类型为 OffsetDateTime。在实体类中对该字段进行注解如下:

import com.baomidou.mybatisplus.annotation.TableField;
import com.baomidou.mybatisplus.annotation.TableName;
import java.time.OffsetDateTime;

@TableName("user") // 表名
public class User {

    // 其他属性省略...

    @TableField(value = "create_time", jdbcType = JdbcType.TIMESTAMP)
    private OffsetDateTime createTime;

    // 其他方法省略...
}

在上面的代码中,我们在 createTime 字段上添加了 @TableField 注解,并使用 jdbcType 参数指定了该字段在数据库中的数据类型为 TIMESTAMP。

总结

在使用 MyBatis-Plus 连接 PostgreSQL 数据库时,遇到 “conversion to class java.time.OffsetDateTime from int4 not supported” 异常,通常是因为实体类字段的数据类型与数据库字段的数据类型不匹配所致。为了解决这个问题,我们可以在实体类中使用 @TableField 注解,并通过 jdbcType 参数明确指定数据库字段的数据类型。本文提供的解决方案可以帮助您顺利解决这个异常,让您的项目顺利运行。

希望本文对您有所帮助!如有疑问或建议,请随时在评论区留言,谢谢阅读!

原创声明

======= ·

  • 原创作者: 猫头虎

作者wx: [ libin9iOak ]

  • 今日已学习

本文为原创文章,版权归作者所有。未经许可,禁止转载、复制或引用。

作者保证信息真实可靠,但不对准确性和完整性承担责任

未经许可,禁止商业用途。

如有疑问或建议,请联系作者。

感谢您的支持与尊重。

点击下方名片,加入IT技术核心学习团队。一起探索科技的未来,共同成长。

更多推荐

电力系统直流潮流分析【N-1】(Matlab代码实现)

💥💥💞💞欢迎来到本博客❤️❤️💥💥🏆博主优势:🌞🌞🌞博客内容尽量做到思维缜密,逻辑清晰,为了方便读者。⛳️座右铭:行百里者,半于九十。📋📋📋本文目录如下:🎁🎁🎁目录💥1概述📚2运行结果🎉3参考文献🌈4Matlab代码及文档讲解💥1概述该程序接受一个感受矩阵B=[NxN]和注入功

springboot集成mybatis-plus

一、在springboot中配置mybatis-plus1、创建一个springboot项目,注意勾选mysql2、在pom.xml文件中添加mybatis-plus的依赖包<?xmlversion="1.0"encoding="UTF-8"?><projectxmlns="http://maven.apache.or

SpringBoot 集成 SpringSecurity 从入门到深入理解

完整的目录介绍SpringSecurity简述SpringSecuritySpringSecurity的主要功能说明项目源码入门案例项目工程路径第一步:加载依赖第二步:创建核心的配置类第三步:增加controller第三步:启动程序小结界面跳转说明密码生成说明重点内容扫盲重要的FilterPasswordEncoder

学习计算机网络中的一些疑问及解答

文章目录前言一、为什么要进行三次握手二、三次握手的流程三、三次握手中seq和ack的值四、四次挥手流程五、四次挥手中seq和ack的值六、为什么要等待才回复七、为什么等待2MSL总结前言一个本硕双非的小菜鸡,备战24年秋招,在学习计算机网络的过程中遇到了一些问题,思考并解答。部分参考小林大佬的解答:小林coding一、

IntelliJ IDEA下基于Scala实现的Git检查工具

本文使用Scala实现自定义的Git检查工具,读者可以基于本文的示例进行扩展与实现,也可以进行其他应用方向的尝试。01、Git检查工具在实现Git检查工具之前需要知道程序究竟要做什么。我们知道,在管理Git分支时可以进行代码合并操作,这样可以将其他开发者提交的内容同步到当前分支中,当用户对自己的分支进行提交时就不会与现

深入理解 Java 异步编程:Future 和 CompletableFuture 的全面比较

深入理解Java异步编程:Future和CompletableFuture的全面比较FutureCompletableFuture选择适合的场景和需求:理解Future和CompletableFuture的底层实现、用法以及它们的优劣势对深入了解这两个概念非常重要。我将从底层开始,详细解释它们,然后根据不同场景和需求讨

评价模型:层次分析法

写在前面:博主本人大学期间参加数学建模竞赛十多余次,获奖等级均在二等奖以上。为了让更多学生在数学建模这条路上少走弯路,故将数学建模常用数学模型算法汇聚于此专栏,希望能够对要参加数学建模比赛的同学们有所帮助。目录1.模型建立1.1建立层次结构模型1.2构造判断矩阵1.3判断矩阵的一致性检验1.4层次总排序及一致性检验2.

Java学习笔记40——Lambda表达式

Lambda表达式Lambda表达式函数式编程思想概述Lambda表达式的标准格式Lambda表达式练习练习1练习2练习3Lambda表达式的省略模式Lambda表达式的注意事项Lambda表达式与接口的区别Lambda表达式函数式编程思想概述面向对象思想强调“必须通过对象的形式做事”在函数式思想中尽量忽略面向对象的复

DipC 构建基因组 3D 结构(学习笔记)

背景本文主要记录了DipC数据的复现过程、学习笔记及注意事项。目录下载SRA数据使用SRAToolkit转换SRA数据为Fastq格式使用bwa比对测序数据使用Hickit计算样本的基因组3D结构使用散点图展示3D结构计算3D结构重复模拟的稳定性其他步骤1.下载SRA数据1.1从NCBI网站下载SRA数据(桌面操作)根

考研英语笔记:好难

文/谷雨不用再去深圳出差了,在公司混日子,备考时间增加了许多。除去数学和专业课,我现在花费在英语上的时间不算多,每天研究一篇经济学人的精读,然后做些习题。今天我看的是8.26期经济学人的一篇文章《AIcouldfortifybigbusiness,notupendit》。fortify本意是筑防御工事以防卫;(尤指)筑

极光笔记 | 极光服务的信创改造实践

什么是信创?信创全称为“信息技术应用创新”,主要包含应用于通信、云计算、大数据、人工智能、工业互联网等诸多高新产业的基础技术。基础技术则包含基础硬件、基础软件、应用软件、信息安全四大板块。其中:基础硬件主要包括:芯片、服务器/PC、存储等;基础软件包括:数据库、操作系统、中间件等;应用软件包括:办公软件、ERP和其它软

热文推荐