mybatis使用generator自己主動生成代碼時的類型轉換
阿新 • • 發佈:2017-05-25
clas 位置 content html long col ati public oracl
類型轉換器MyJavaTypeResolver主要代碼
使用mybatis的generator自己主動生成代碼,可是oracle數據庫中number(6,2)總是自己主動轉成BigDecimal。我想要轉成的是float類型
這樣就寫了一個類型轉換器,須要繼承JavaTypeResolver接口
然後在mybaties配置文件generatorConfig.xml中類型轉換配置位置加入上就可以
<javaTypeResolver type="com.generator.MyJavaTypeResolver"> <property name="forceBigDecimals" value="false" /> <!-- 類型解析器 --> </javaTypeResolver>
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; }
mybatis使用generator自己主動生成代碼時的類型轉換