mybatis使用generator自动生成代码时的类型转换
程序员文章站
2024-01-27 19:58:28
...
使用mybatis的generator自动生成代码,但是oracle数据库中number(6,2)总是自动转成BigDecimal,我想要转成的是float类型 这样就写了一个类型转换器,需要继承JavaTypeResolver接口 然后在mybaties配置文件generatorConfig.xml中类型转换配置位置添加上即可 j
使用mybatis的generator自动生成代码,但是oracle数据库中number(6,2)总是自动转成BigDecimal,我想要转成的是float类型
这样就写了一个类型转换器,需要继承JavaTypeResolver接口
然后在mybaties配置文件generatorConfig.xml中类型转换配置位置添加上即可
类型转换器MyJavaTypeResolver主要代码
public FullyQualifiedJavaType calculateJavaType( IntrospectedColumn introspectedColumn) { // TODO Auto-generated method stub FullyQualifiedJavaType answer; JdbcTypeInformation jdbcTypeInformation = typeMap .get(introspectedColumn.getJdbcType()); if (jdbcTypeInformation == null) { switch (introspectedColumn.getJdbcType()) { case Types.DECIMAL: case Types.NUMERIC: if(introspectedColumn.getScale() > 0) {//如果包含小数点则转换成float answer = new FullyQualifiedJavaType(Float.class.getName()); }else{ if ( introspectedColumn.getLength() > 18 || forceBigDecimals) { answer = new FullyQualifiedJavaType(BigDecimal.class .getName()); } else if (introspectedColumn.getLength() > 9) { answer = new FullyQualifiedJavaType(Long.class.getName()); } else if (introspectedColumn.getLength() > 4) { answer = new FullyQualifiedJavaType(Integer.class.getName()); } else { answer = new FullyQualifiedJavaType(Short.class.getName()); } } break; default: answer = null; break; } } else { answer = jdbcTypeInformation.getFullyQualifiedJavaType(); } return answer; }
上一篇: Mysql编写定时任务事件
下一篇: 关于FTP上传文件问题
推荐阅读
-
mybatis使用generator自动生成代码时的类型转换
-
Idea使用Mybatis Generator 自动生成代码
-
idea使用generator自动生成mybatis代码
-
Spring和MyBatis整合自动生成代码里面text类型遇到的坑
-
Spring和MyBatis整合自动生成代码里面text类型遇到的坑
-
代码生成神器:MyBatis Generator的使用
-
Intellij IDEA中使用MyBatis-generator 自动生成MyBatis代码
-
MyBatis代码自动生成器Mybatis-Generator使用教程
-
IDEA 中使用MyBatis-generator 自动生成MyBatis代码
-
MyBatis使用Generator自动生成代码