之前都是百度上搜的,各种对应的都有,总觉得有问题,最后直接通过跑代码查看了一下对应关系,我用的oracle是19c。
常见的对应关系如下
oracle类型 | jdbcType |
---|---|
VARCHAR2 | JdbcType.VARCHAR |
NVARCHAR | JdbcType.NVARCHAR |
CHAR | JdbcType.CHAR |
CLOB | JdbcType.CLOB |
BLOB | JdbcType.BLOB |
NCLOB | JdbcType.NCLOB |
NUMBER | JdbcType.NUMERIC |
DATE | JdbcType.TIMESTAMP |
TIMESTAMP | JdbcType.TIMESTAMP |
NUMBER(*),NUMBER(2),NUMBER(2,2),NUMBER(0,2)这种都是JdbcType.NUMERIC
找对应关系的步骤:
-
oracle中建一张表,多弄一个属性,每个属性一个类型
忽略表名和列名😂,这里注意一下这几个NUMBER类型,有的类型其实我建的是INTERGE和DECIMA,但是实际上表建好之后,还是使用的NUMBER,这个有疑惑的可以去百度一下,大概就是oracle数字类型的其实只有NUMBER,其他一些整数类型啥的都是建立在NUMBER上的。
-
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(); // 遍历结果集并查询jdbcType while (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不是同一个名称 -
打开org.apache.ibatis.type.JdbcType枚举源码和java.sql.Types源码,mybatis中的JdbcType是对应的java中的Types类中的编码,直接拿着前面代码执行结果中的编码去Types类中找常量,然后再来JdbcType枚举类中找对应枚举。
java.sql下面其实也有一个JDBCType类,这里不管