Oracle Number类型

NUMBER类型

 

定义

 

定义格式NUMBER (precision,scale)

precision表示数字中的有效位(从左边第一个不为0的数算起,小数点和负号不计入有效位数),取值范围为【1-38】默认38。

scale表示精确到多少位,取值范围为【-84-127】,默认值为0。大于零时,表示数字精确到小数点右边的位数;小于零时,将把该数字取舍到小数点左边的指定位数,所以,NUMBER整数部分允许的长度为(precision- scale),无论scale是正数还是负数,并且,如果precision小于scale,表示存储的是没有整数的小数。

关于number的精度(p)和刻度(s)遵循以下规则:

1)  当一个数的整数部分的长度> p-s 时,Oracle就会报错

2)  当一个数的小数部分的长度> s 时,Oracle就会舍入。

3)  当s(scale)为负数时,Oracle就对小数点左边的s个数字进行舍入。

4)  当s > p 时, p表示小数点后第s位向左最多可以有多少位数字,如果大于p则Oracle报错,小数点后s位向右的数字被舍入

 

案例

实际值

数据类型

存储值

1234567.89

Number

1234567.89

1234567.89

Number(8)

1234567

1234567.89

Number(6)

出错

1234567.89

Number(9,1)

1234567.9

1234567.89

Number(9,3)

出错

1234567.89

Number(7,2)

出错

1234567.89

Number(5,-2)

1234600

1234511.89

Number(5,-2)

1234500

1234567.89

Number(5,-4)

1230000

1234567.89

Number(*,1)

1234567.9

0.012

Number(2,3)

0.012

0.23

Number(2,3)

出错

NUMBER类型的子类

 

decimal,numeric,int等都为SQL、DB2等数据库的数据类型,ORACLE为了兼容才将其引入;但实际上在ORACLE内部还是以NUMBER的形式将其存入,所以在集合关系上它们也都是number的子集。

int类型只能存储整数;

在oracle数据库建表的时候,decimal,numeric不带精度,oracle会自动把它处理成INTEGER;带精度,oracle会自动把它处理成number。

Oracle只用NUMBER(m,n)就可以表示任何复杂的数值数据。

 

select table_name,column_name,data_type,data_length,data_precision,data_scale from dba_tab_columns a WHERE a.TABLE_NAME = 'T_IFS_TRANSMISSION_LOG';


--Data_type表示字段类型;
--Data_length表示字段类型的长度;
--Data_Precision表示字段类型的精度的总长度,如果为null,表示精度的总长度不固定,最长为Data_Length;
--Data_scale表示字段类型的精度范围,如果为0,表示只能存储为整数,
--如果为null,表示可以存储整数或者浮点数,浮点数位数不确定,
--如果为整数,表示存储的精度位数。

posted @ 2024-09-23 18:09  未来的羁绊  阅读(223)  评论(0编辑  收藏  举报