zoukankan      html  css  js  c++  java
  • 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;  
        }  
  • 相关阅读:
    Partition HDU
    FFT版题 [51 Nod 1028] 大数乘法
    [51Nod 1220]
    [bzoj 4176] Lucas的数论 (杜教筛 + 莫比乌斯反演)
    [51Nod 1222]
    [51Nod 1227] 平均最小公倍数 (杜教筛)
    算法-05-二分查找第一个出现的数 美团一面
    Hbase-00-MAC 安装Hbase 单机模式
    算法-04-用两个栈实现队列
    算法-03-Java 实现阻塞队列 字节三面算法题
  • 原文地址:https://www.cnblogs.com/liaojie970/p/8029050.html
Copyright © 2011-2022 走看看