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

2023-12-14 14:04

本文主要是介绍mybatis与oracle数据库jdbcType类型对应关系,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

之前都是百度上搜的,各种对应的都有,总觉得有问题,最后直接通过跑代码查看了一下对应关系,我用的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类,这里不管
    在这里插入图片描述
    在这里插入图片描述

这篇关于mybatis与oracle数据库jdbcType类型对应关系的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/492818

相关文章

MyBatis-Plus通用中等、大量数据分批查询和处理方法

《MyBatis-Plus通用中等、大量数据分批查询和处理方法》文章介绍MyBatis-Plus分页查询处理,通过函数式接口与Lambda表达式实现通用逻辑,方法抽象但功能强大,建议扩展分批处理及流式... 目录函数式接口获取分页数据接口数据处理接口通用逻辑工具类使用方法简单查询自定义查询方法总结函数式接口

SQL server数据库如何下载和安装

《SQLserver数据库如何下载和安装》本文指导如何下载安装SQLServer2022评估版及SSMS工具,涵盖安装配置、连接字符串设置、C#连接数据库方法和安全注意事项,如混合验证、参数化查... 目录第一步:打开官网下载对应文件第二步:程序安装配置第三部:安装工具SQL Server Manageme

C#连接SQL server数据库命令的基本步骤

《C#连接SQLserver数据库命令的基本步骤》文章讲解了连接SQLServer数据库的步骤,包括引入命名空间、构建连接字符串、使用SqlConnection和SqlCommand执行SQL操作,... 目录建议配合使用:如何下载和安装SQL server数据库-CSDN博客1. 引入必要的命名空间2.

MyBatis中$与#的区别解析

《MyBatis中$与#的区别解析》文章浏览阅读314次,点赞4次,收藏6次。MyBatis使用#{}作为参数占位符时,会创建预处理语句(PreparedStatement),并将参数值作为预处理语句... 目录一、介绍二、sql注入风险实例一、介绍#(井号):MyBATis使用#{}作为参数占位符时,会

mybatis执行insert返回id实现详解

《mybatis执行insert返回id实现详解》MyBatis插入操作默认返回受影响行数,需通过useGeneratedKeys+keyProperty或selectKey获取主键ID,确保主键为自... 目录 两种方式获取自增 ID:1. ​​useGeneratedKeys+keyProperty(推

Java通过驱动包(jar包)连接MySQL数据库的步骤总结及验证方式

《Java通过驱动包(jar包)连接MySQL数据库的步骤总结及验证方式》本文详细介绍如何使用Java通过JDBC连接MySQL数据库,包括下载驱动、配置Eclipse环境、检测数据库连接等关键步骤,... 目录一、下载驱动包二、放jar包三、检测数据库连接JavaJava 如何使用 JDBC 连接 mys

MyBatis-Plus 中 nested() 与 and() 方法详解(最佳实践场景)

《MyBatis-Plus中nested()与and()方法详解(最佳实践场景)》在MyBatis-Plus的条件构造器中,nested()和and()都是用于构建复杂查询条件的关键方法,但... 目录MyBATis-Plus 中nested()与and()方法详解一、核心区别对比二、方法详解1.and()

java中新生代和老生代的关系说明

《java中新生代和老生代的关系说明》:本文主要介绍java中新生代和老生代的关系说明,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、内存区域划分新生代老年代二、对象生命周期与晋升流程三、新生代与老年代的协作机制1. 跨代引用处理2. 动态年龄判定3. 空间分

MySQL数据库中ENUM的用法是什么详解

《MySQL数据库中ENUM的用法是什么详解》ENUM是一个字符串对象,用于指定一组预定义的值,并可在创建表时使用,下面:本文主要介绍MySQL数据库中ENUM的用法是什么的相关资料,文中通过代码... 目录mysql 中 ENUM 的用法一、ENUM 的定义与语法二、ENUM 的特点三、ENUM 的用法1

Java中调用数据库存储过程的示例代码

《Java中调用数据库存储过程的示例代码》本文介绍Java通过JDBC调用数据库存储过程的方法,涵盖参数类型、执行步骤及数据库差异,需注意异常处理与资源管理,以优化性能并实现复杂业务逻辑,感兴趣的朋友... 目录一、存储过程概述二、Java调用存储过程的基本javascript步骤三、Java调用存储过程示