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