使用MyBatise的代碼自動生成工具時候,即便在配置文件中定義了
<javaTypeResolver> <property name="forceBigDecimals" value="false" /> </javaTypeResolver>
生成之后的實體中number類型轉換成JAVA類型還是會被轉換為BigDecimal類型。
測試發現:
Oracle數據庫,用mybatis-gen.xml 自動生成Java對象的時候,會根據number類型的長度不同生成不同的數據類型
| number長度 | Java類型 |
| 1~4 | Short |
| 5~9 | Integer |
| 10~18 | Long |
| 18+ | BigDecimal |
所以必須指定number類型的大小
########################################################################
或者自定義一個類型轉換器,繼承JavaTypeResolver接口
然后在mybaties配置文件generatorConfig.xml中類型轉換配置位置添加上即可
<javaTypeResolver type="com.generator.MyJavaTypeResolver"> <property name="forceBigDecimals" value="false" /> <!-- 類型解析器 --> </javaTypeResolver>
類型轉換器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; }
