MyBatise代码自动生成时候Oralce的number类型BigDecimal问题
2017-12-12 18:00
531 查看
使用MyBatise的代码自动生成工具时候,即便在配置文件中定义了
生成之后的实体中number类型转换成JAVA类型还是会被转换为BigDecimal类型。
测试发现:
Oracle数据库,用mybatis-gen.xml 自动生成Java对象的时候,会根据number类型的长度不同生成不同的数据类型
所以必须指定number类型的大小
########################################################################
或者自定义一个类型转换器,继承JavaTypeResolver接口
然后在mybaties配置文件generatorConfig.xml中类型转换配置位置添加上即可
类型转换器MyJavaTypeResolver主要代码
<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 |
########################################################################
或者自定义一个类型转换器,继承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; }
相关文章推荐
- MyBatise代码自动生成时候Oralce的number类型BigDecimal问题
- MyBatise代码自动生成时候Oralce的number类型BigDecimal问题
- MyBaties自动生成sql server代码number类型变为BigDecimal
- Eclipse+CDT自动生成的代码 C++ 头文件重名问题
- 开发日志:struts标签[<s:selec>/<s:submit>/<s:form>......] 在table的时候位置错误 [会自动换行/自动生成tr、td的问题]
- 自制工具:CSV代码生成器:自动生成CSV文件对应的C++实体类和字段类型解析代码
- 使用abator自动生成代码时要注意的问题
- mfc中自动生成的“CView::OnLButtonDown(nFlags, point);”代码问题
- jfinal 的maven项目自动生成代码路径问题
- Eclipse新建Servlet时候,不会自动生成mapping到web.xml,而是在代码中加入注解@WebServlet
- 自制工具:CSV代码生成器:自动生成CSV文件对应的C++实体类和字段类型解析代码
- Dagger2的自动代码生成问题
- 一个VS.net自动生成代码引发的问题
- 关于Oracle字段类型Date使用mybatis generator自动生成工具出现的查询日期只精确到年月日问题
- 七牛对私有空间请求pm3u8操作时候生成私有凭证,java 旧版sdk存在的代码逻辑问题。
- mybatis使用generator自动生成代码时的类型转换
- eclipse 开发android 项目的时候系统自动生成的R.Java文件在重新生成时候丢失问题
- 关于BigDecimal在MySQL和Oracle中设计表的时候如何设计其类型的问题
- yii框架,gii自动生成代码;yi权限访问的问题:
- access如何用代码在“默认值”里实现自动编号?单据流水号生成问题。