mybatis与oracle数据库jdbcType类型对应关系

news/2025/2/12 1:04:40/

之前都是百度上搜的,各种对应的都有,总觉得有问题,最后直接通过跑代码查看了一下对应关系,我用的oracle是19c。
常见的对应关系如下

oracle类型jdbcType
VARCHAR2JdbcType.VARCHAR
NVARCHARJdbcType.NVARCHAR
CHARJdbcType.CHAR
CLOBJdbcType.CLOB
BLOBJdbcType.BLOB
NCLOBJdbcType.NCLOB
NUMBERJdbcType.NUMERIC
DATEJdbcType.TIMESTAMP
TIMESTAMPJdbcType.TIMESTAMP

NUMBER(*),NUMBER(2),NUMBER(2,2),NUMBER(0,2)这种都是JdbcType.NUMERIC

找对应关系的步骤:

  1. oracle中建一张表,多弄一个属性,每个属性一个类型
    忽略表名和列名😂,这里注意一下这几个NUMBER类型,有的类型其实我建的是INTERGE和DECIMA,但是实际上表建好之后,还是使用的NUMBER,这个有疑惑的可以去百度一下,大概就是oracle数字类型的其实只有NUMBER,其他一些整数类型啥的都是建立在NUMBER上的。
    在这里插入图片描述

  2. java中用jdbc查看jdbcType

    @Test
    public void testDD() {try {// 加载数据库驱动程序Class.forName("oracle.jdbc.OracleDriver");// 建立数据库连接Connection conn = DriverManager.getConnection("jdbc:oracle:thin:@你的ip:1521/xxxxx", "用户名", "密码");// 创建Statement对象Statement stmt = conn.createStatement();// 执行查询语句ResultSet rs = stmt.executeQuery("select * from AAAA");// 获取结果集元数据ResultSetMetaData metaData = rs.getMetaData();// 遍历结果集并查询jdbcTypewhile (rs.next()) {for (int i = 1; i <= metaData.getColumnCount(); i++) {int jdbcType = metaData.getColumnType(i);String columnTypeName = metaData.getColumnTypeName(i);// 输出jdbcType的编码和名称System.out.println("Column " + metaData.getColumnName(i) + " has jdbcType: " + jdbcType + " has name " + columnTypeName);}}// 关闭连接和释放资源rs.close();stmt.close();conn.close();} catch (ClassNotFoundException e) {e.printStackTrace();} catch (SQLException e) {e.printStackTrace();}
    }
    

    运行上面的代码,得到的结果截图
    在这里插入图片描述
    注意这个类型名称和mybatis的JdbcType不是同一个名称

  3. 打开org.apache.ibatis.type.JdbcType枚举源码和java.sql.Types源码,mybatis中的JdbcType是对应的java中的Types类中的编码,直接拿着前面代码执行结果中的编码去Types类中找常量,然后再来JdbcType枚举类中找对应枚举。
    java.sql下面其实也有一个JDBCType类,这里不管
    在这里插入图片描述
    在这里插入图片描述


http://www.ppmy.cn/news/1268799.html

相关文章

AV1编码技术分享:开启下一代视频编码时代

目录 导论 第一部分&#xff1a;AV1的背景与发展 1.1 视频编码的演进 1.2 AOMedia联盟的成立 第二部分&#xff1a;AV1编码技术的原理 2.1 AV1的压缩算法 2.2 自适应量化 2.3 多级运动矢量预测 2.4 色彩空间和位深度的提升 第三部分&#xff1a;AV1的特点与优势 3.1 …

SQL进阶理论篇(二):数据库的设计范式

文章目录 简介数据库的设计范式有哪些数据库中的几种键从1NF到3NF1NF2NF3NFBCNF&#xff08;巴斯范式&#xff09; 反范式设计反范式的适用场景总结参考文献 简介 本小节主要内容&#xff1a; 数据库的设计范式都有哪些数据库的键都有哪些1NF、2NF和3NF都是指什么&#xff1f…

word四级目录序号不随上级目录序号变化问题解决方法

一、word中的几个元素简介 1、word中的列表 如下图所示&#xff0c;代表word的列表&#xff1a; 2、word中的标题 如下图所示&#xff0c;代表word的标题&#xff1a; 3、word中的编号/序号 如下图所示&#xff0c;代表word的编号/序号&#xff1a; 4、word中的目录 如下图…

复旦微用AXIDMA接收原始图像

参考SD卡移植博客&#xff0c;&#xff0c;移植SD卡相应代码 AXIDMA部分Demo下的bsp包整个pl搬到相应位置&#xff0c;添加相应文件 #include <stdio.h> #include <stdlib.h> #include "platform.h" #include "fmsh_common.h" #include "…

07.Go 流程控制

流程控制是Go语言中必不可少的一部分&#xff0c;也是整个编程基础的重要一环。Go语言的流程控制语句和其他编程语言的流程控制语句有些不同&#xff0c;主要体现在Go语言没有do-while语句。Go语言常用的流程控制包括if语句、switch语句、for语句及goto语句等&#xff0c;switc…

Hasura GraphQL Engine 远程命令执行漏洞复现 [附POC]

文章目录 Hasura GraphQL Engine 远程命令执行漏洞复现 [附POC]0x01 前言0x02 漏洞描述0x03 影响版本0x04 漏洞环境0x05 漏洞复现1.访问漏洞环境2.构造POC3.复现0x06 修复建议Hasura GraphQL Engine 远程命令执行漏洞复现 [附POC] 0x01 前言 免责声明:请勿利用文章内的相关技…

Java8新特性:函数式(Functional)接口

我是南城余&#xff01;阿里云开发者平台专家博士证书获得者&#xff01; 欢迎关注我的博客&#xff01;一同成长&#xff01; 一名从事运维开发的worker&#xff0c;记录分享学习。 专注于AI&#xff0c;运维开发&#xff0c;windows Linux 系统领域的分享&#xff01; 本…

Excel: Python 如何干掉 VBA 系列 丙

以下内容为本人的学习笔记&#xff0c;如需要转载&#xff0c;请声明原文链接 微信公众号「ENG八戒」https://mp.weixin.qq.com/s/FgoU8CxofwY90f3IX2Tpww 获取网络动态数据 本文开始之前夸过海口&#xff0c;说要演示一下喂养家畜的饲料动态成本&#xff0c;其实由于行业数据…