MyBatise代碼自動生成時候Oralce的number類型BigDecimal問題


使用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;  
    }  

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM