oracle与yashanDB的jdbc返回常量列"0.00"的精度和刻度不一致
问题现象
客户预期常量列"0.00"应该映射到java里的浮点类型,结果却是跑到整型。
1、应用的sql
2、应用的java代码
3、执行结果
问题的风险及影响
客户查询信息失败
问题影响的版本
23.2.4.25
问题发生原因
oracle与yashanDB的jdbc返回常量列"0.00"的精度和刻度不一致。
如果常量列是整型或浮点型oracle的jdbc返回都是number类型,且是未定义的。
因在未定义情况下,精度 precision=0 刻度scale=-127,刚好走到java FieldType.float分支,符合预期。
如果是整型精度刻度也是这个值,java程序也会走到FieldType.float分支将不符合预期。
解决方法及规避方式
修改java程序,对int和float类型都使用java里的decimal类型接收,在解析字符值是根据字符实际类型解析。
问题分析和处理过程
使用以下java代码分别在oracle和yashandb的jdbc驱动下执行“select 0.0 from dual"
通过 java.sql.ResultSetMetaData 获取精度和刻度。
经验总结
oracle数值类型只有number类型,float和integer都只是number类型的子类。
且oracle的类型number类型还有未定义状态,此时取精度(precision)和刻度(scale)
都是不准确的,如果是未定义状态,还是通过精度和刻度判断是否能够转换为整型也是不严谨的,
当应用从oracle环境迁到崖山环境,要格外留意这点。
友情链接:深圳计算科学研究院 深圳崖山科技有限公司
版权所有© 深圳崖山科技有限公司 粤ICP备2022018810号
公众号
加入技术交流群
YashanDB
崖山数据库系统YashanDB是深圳计算科学研究院自主设计研发的新型数据库管理系统,融入原创的有界计算、近似计算、并行可扩展和跨模融合计算理论,可满足金融、政企、能源等关键行业对高性能、高并发及高安全性的要求。
邮箱:info@yashandb.com
地址:广东省深圳市龙华区民宝路红山6979园区25座5-10层