写点什么

【YashanDB 知识库】oracle 与 yashanDB 的 jdbc 返回常量列"0.00"的精度和刻度不一致

作者:YashanDB
  • 2024-12-13
    广东
  • 本文字数:572 字

    阅读完需:约 2 分钟

本文内容来自 YashanDB 官网,原文内容请见:https://www.yashandb.com/newsinfo/7610110.html?templateId=1718516


问题现象

客户预期常量列"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 环境迁到崖山环境,要格外留意这点。

发布于: 刚刚阅读数: 6
用户头像

YashanDB

关注

全自研国产新型大数据管理系统 2022-02-15 加入

还未添加个人简介

评论

发布
暂无评论
【YashanDB知识库】oracle与yashanDB的jdbc返回常量列"0.00"的精度和刻度不一致_数据库_YashanDB_InfoQ写作社区