Oracle数据类型之number

oracle的number类型是oracle的内置类型之一,是oracle的最基础数值数据类型。在9iR2及其以前的版本中只支持一种适合存储数值数据的固有数据类型,在10g以后,才出现了两种新的数值类型,即推出本地浮点数据类型(Native Floating-Point Data Types): BINARY_FLOAT(单精度32位)和BINARY_DOUBLE(双精度64位). 这些新数据类型都是基于IEEE二进制浮点运算标准,ANSI/IEEE Std 754-1985 [IEEE 754],使用这些类型时要加上文字f(BINARY_FLOAT)或者d(BINARY_DOUBLE),比如2.07f、3.000094d。

number数据类型

number类型的语法很简单:number(p,s):
p:精度位,precision,是总有效数据位数,取值范围是38,默认是38,可以用字符*表示38。
s:小数位,scale,是小数点右边的位数,取值范围是-84~127,默认值取决于p,如果没有指定p,那么s是最大范围,如果指定了p,那么s=0。
p:is the precision,or the total number of digits. Oracle guarantees the portability of numbers with precision ranging from 1 to 38.
s:is the scale, or the number of digits to the right of the decimal point. The scale can range from -84 to 127.

number类型的p和s,与其底层存储完全没有关系,根本不会影响数据在磁盘上如何存储,它只会影响允许哪些值以及数值如何舍入,你可以认为其是对数据的“编辑”。简单的说,精度位p表示数值最多能有多少个有效数字,而小数位s表示最多能有多少位小数。换句话说,p表示一共有多少位有效数字(即小数点左边最多有p-s位有效数字),s表示小数点右边有s位有效数字。如number(5,2)类型的数据,就表示小数点左边最多有3位有效数字,右边最多有2位有效数字,加起来就是最多有5位有效数字,超过这个范围的数字就不能正确的存储下来,注意这里说的是不能正确存储,但并不是不能存储。

最高整数位数=p-s
s正数,小数点右边指定位置开始四舍五入
s负数,小数点左边指定位置开始四舍五入
s是0或者未指定,四舍五入到最近整数
当p小于s时候,表示数字是绝对值小于1的数字,且从小数点右边开始的前s-p位必须是0,保留s位小数。

p>0,对s分2种情况:
1. s>0
精确到小数点右边s位,并四舍五入。然后检验有效数位是否<=p;如果s>p,小数点右边至少有s-p个0填充。
2. s<0

精确到小数点左边s位,并四舍五入。然后检验有效数位是否<=p+|s|

具体数据可参考下表

Value

Datatype

Stored Value

123.2564

NUMBER

123.2564

1234.9876

NUMBER(6,2)

1234.99

12345.12345

NUMBER(6,2)

Error

1234.9876

NUMBER(6)

1235

12345.345

NUMBER(5,-2)

12300

1234567

NUMBER(5,-2)

1234600

12345678

NUMBER(5,-2)

Error

123456789

NUMBER(5,-4)

123460000

1234567890

NUMBER(5,-4)

Error

12345.58

NUMBER(*, 1)

12345.6

0.1

NUMBER(4,5)

Error

0.01234567

NUMBER(4,5)

0.01235

0.09999

NUMBER(4,5)

0.09999

0.099996

NUMBER(4,5)

Error


想了解更详细的可以参考这个链接http://www.blogjava.net/caojianhua/archive/2011/01/24/343461.html

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
NUMBEROracle数据库中的一种数据类型,用于存储数值数据。它可以存储整数、小数和负数,并且具有可调节的精度和小数位数。 以下是关于Oracle NUMBER数据类型的一些重要信息: - NUMBER类型的数据范围是1×10^-130 ~ 1 × 10^126,超出这个范围会导致错误。 - NUMBER类型的定义可以包括精度和小数位数,格式为NUMBER(precision, scale)。其中,precision表示有效位数(取值范围为1~38),scale表示小数点后的位数(取值范围为-84~127)。 - 当精度超出定义时,Oracle会进行四舍五入操作。 - 一个NUMBER类型的数据在数据库中占用1~22个字节的存储空间,具体取决于精度和小数位数的定义。 - 实际数据存储类型与定义的精度和小数位数有关。例如,存储值为123.89的NUMBER类型数据,如果定义为NUMBER(3),则存储为124;如果定义为NUMBER(5, 4),则存储为123.8912。 - 如果定义的精度和小数位数超过实际数据的范围,Oracle会进行截断或四舍五入操作。 下面是一个示例,演示了如何在Oracle中使用NUMBER数据类型: ```sql CREATE TABLE my_table ( id NUMBER(10), value NUMBER(8, 2) ); INSERT INTO my_table (id, value) VALUES (1, 123.45); INSERT INTO my_table (id, value) VALUES (2, 678.90); SELECT * FROM my_table; ``` 这个示例创建了一个名为my_table的表,其中包含id和value两个列,它们的数据类型分别为NUMBER(10)和NUMBER(8, 2)。然后,通过INSERT语句向表中插入了两行数据。最后,使用SELECT语句检索并显示了表中的所有数据。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值