Oracle number类型前端界面和数据库查询不一致 number精度问题
【发现问题】
【问题分析】
Ⅰ、在前端界面查询,发现了库存中存在这样的数量值。但是在数据库中查询时显示正常。即6.999999999999997 为 7。
Ⅱ、至于这种小数产生,我以为是oracle存储过程计算的时候也会失真?后来发现我这是由于其他问题造成的。
🌂对于前端和数据库的查询结果不一致,我也很纳闷。于是,我把数据里面的7,进行重写,这样前端就显示正常了。于是我推断,前端界面显示的数据库值是准确的,而我们查询的结果进行了一些处理,导致6.999999999999997查看到的结果是7。
Ⅳ、数据库会默认6.999999999999997为Number,查询的结果如下:
🌫如果我们将Number类型的数据进行一个to_char的处理,如下:(可以发现,数据完整显示)
⑥前端显示 2E-12 ,那么它实际的值是多少呢?可以通过 to_char() 来显示它原来的值。最后发现0.000000000002这样的值,number类型显示如下:
【知识补充】
①百度知识
- Oracle Number类型是以十进制形式存储整数和浮点数,语法为 Number( p , s ) 。
- 其中 p 为精度,即所有有效数字位数; s 为刻度范围,即小数位数。 p 的取值范围是 1~38,s的取值范围范围从
-84
到127
- 在此我也查询了一些资料,精度和刻度的限制是在插入时,根据精度和刻度对插入的值进行一个四舍五入的处理以及限制。并没有提到和 select 查询的关系。
PS:看完这写也并不知道说的是···,感觉自己没用到这东西。但是大概的意思是:
- 我们是设计数据库的时候,常用的类型用 VARCHAR2 类型,一般我们会指定 字符的长度,好像是必须指定的。但是 Number 类型我们一般不设置他的精度和刻度范围。
- 那么这个精度和刻度就是像 VARCHAR2 写法相同。如下:
- p设置为0,s设置大于0,会提示类型不正确
NUMBER(0,5)
- p设置为大于0,s设置0,显示为 Number(p)
- NUMBER(5,-2) 表示有效位为5位,小数点左边两位进行四舍五入。即 插入11268 存11300
- NUMBER(5,2) 表示有效位5位,小数位后最多两位进行四舍五入。即插入 123.356 存 123.36
- 如果四舍五入后的位数超过最大有效位置,将会出错。即 NUMBER(5,-1) 插入 99999 四舍五入之后 100000 超过有效位数出错。
- 保留到小数点后几位不看有效位数。
NUMBER(*,1)
②我们一般会直接使用Number类型,那么默认的 精度和刻度 又是多少呢?
- 创建一张表作为测试
create Table num_dome (
NUM_VAL NUMBER
);
- 将数据类型设置为NUMBER类型,我们插入一个除不尽的小数,以此来判断它的最大刻度。
insert into num_dome values (2/3)
PS: 最大精度38,这里小数位后有39位什么意思?
- select 查询查看显示结果(小数点后15位)
- 插入一个大于10的小数(前面两位,小数点后37位。数字位39位和上方相同)
- 查看查询的关系(数字位数为15位)
【问题思考】
- 插入的值是有小数的,并且不为0 ,说明刻度 s 大于0 ,若 s>0 那么最大有效位为 p,即39??p的取值范围为 1~38 ?
- 若 p就为39,那么 s 的值好像是变化的 s=39-p。他们是否存在这样的一个动态关系?是否 s 一定要是一个明确的数字?
- select查询和数据库存储相同,只不过把位数缩短了,取15位进行显示。
这些问题其实并没有太大的影响,但一直想弄明白。包括也查了一些资料,并没有得到确切的答案。
本文是自己对Number类型精度刻度的思考,如有错误,请务必告知。(这篇一直零散的写了几天,一直在想通过什么样的方式去测试,以及能够得出什么样的结论)