之前都是百度上搜的,各种对应的都有,总觉得有问题,最后直接通过跑代码查看了一下对应关系,我用的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();// 遍历结果集并查询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不是同一个名称 -
打开org.apache.ibatis.type.JdbcType枚举源码和java.sql.Types源码,mybatis中的JdbcType是对应的java中的Types类中的编码,直接拿着前面代码执行结果中的编码去Types类中找常量,然后再来JdbcType枚举类中找对应枚举。
java.sql下面其实也有一个JDBCType类,这里不管