float和double的範圍是由指數的位數來決定的。
float的指數位有8位,而double的指數位有11位,分佈以下:
float:
1bit(符號位) 8bits(指數位) 23bits(尾數位)
double:
1bit(符號位) 11bits(指數位) 52bits(尾數位)
因而,float的指數範圍爲-127~+128,而double的指數範圍爲-1023~+1024,而且指數位是按補碼的形式來劃分的。
其中負指數決定了浮點數所能表達的絕對值最小的非零數;而正指數決定了浮點數所能表達的絕對值最大的數,也即決定了浮點數的取值範圍。
float的範圍爲-2^128 ~ +2^128,也即-3.40E+38 ~ +3.40E+38;double的範圍爲-2^1024 ~ +2^1024,也即-1.79E+308 ~ +1.79E+308。spa
double:2^52 = 4503599627370496,一共16位,同理,double的精度爲15~16位。code
在Oracle中Number類型能夠用來存儲0,正負定點或者浮點數,可表示的數據範圍在
1.0 * 10(-130) —— 9.9...9 * 10(125) {38個9後邊帶88個0}
的數字,當Oracle中的數學表達式的值>=1.0*10(126)時,Oracle就會報錯。
Number的數據聲明以下:
表示 做用 說明
Number(p, s) 聲明一個定點數 p(precision)爲精度,s(scale)表示小數點右邊的數字個數,精度最大值爲38,
Number(p) 聲明一個整數 至關於Number(p, 0)
Number 聲明一個浮點數 其精度爲38,要注意的是scale的值沒有應用,也就是說scale的指不能簡單的理解爲0,或者其餘的數。內存
定點數的精度(p)和刻度(s)遵循如下規則:
ci
當一個數的整數部分的長度 > p-s 時,Oracle就會報錯同步
當一個數的小數部分的長度 > s 時,Oracle就會舍入。數學
當s(scale)爲負數時,Oracle就對小數點左邊的s個數字進行舍入。it
當s > p 時, p表示小數點後第s位向左最多能夠有多少位數字,若是大於p則Oracle報錯,小數點後s位向右的數字被舍入io
create or replace function func_test(p_type number) return number is /* 功能:基於警度圖數據同步 */ l_cnt number; begin select p_type into l_cnt from dual; return l_cnt; end func_test; / show err; 5.結論 number 的總長度是40位,其中可能包括:小數點,負號位。 select to_char(func_test(-987.1234567891234567891234567891234567891234)) from dual; -987.12345678912345678912345678912345679 //包括小數點及負號位共40位 select to_char(func_test(9876.1234567891234567891234567891234567891234)) from dual; 9876.12345678912345678912345678912345679 //4位整數+小數點+35位小數=40位 select to_char(func_test(987.1234567891234567891234567891234567891234)) from dual; 987.123456789123456789123456789123456789 //3位整數+小數點+36位小數=40位 select to_char(func_test(1234567891234567891234567891234567891234)) from dual; 1234567891234567891234567891234567891234 //40位整數 select to_char(func_test(12345678912345678912345678912345678912345)) from dual; 1.2345678912345678912345678912345679E+40 //41位時精度發生丟失 1.2345678912345678912345678912345679×10^40 即 12345678912345678912345678912345678900000