您的位置:首页 > 数据库 > Oracle

oracle中扩充number类型

2017-09-09 16:27 204 查看

扩充number类型字段精度

周五收到需求要给数据库表中一个number类型的字段增加精度,从保留2位小数位变为保留8位小数位。

按照正常数据库字段变更的顺序,应该是这么做:

新建一张表从原表复制全部表结构和数据;

清空原表所有的数据;

修改原表字段属性;

从临时表拖回全部数据;

删除临时表

代码如下:

CREATE TABLE TABLE_BAK AS SELECT * FROM TABLE;
TRUNCATE TABLE TABLE;
ALTER TABLE TABLE MODIFY CZ_PERC NUMBER(20,8);
INSERT INTO TABLE (SELECT * FROM TABLE_BAK);
DROP TABLE TABLE_BAK;


这个地方注意一下number类型,这个字段最开始是(10,2),我在修改的第一次修改成了(10,8),字段修改的sql没有问题,可在插入数据的时候就开始报字段超长错误。按理讲我扩充了字段有效小数位,是不应该出现这种问题的,但由于没有注意到原来number类型的有效位数是10,导致表结构修改后只能插入大小介于0-100之间的数字,原有数据中如果有超过100的数字,就会超长而不能插入。

number类型字段详解

number(m,n),其中m表示当前字段的有效数字位数,n表示小数位位数,oracle对m和n的取值范围也做了一定的限制:

1 <= m <= 38

-84 <= n <= 127

n > 0

精确到小数点右边n位,并四舍五入。然后检验有效位是否 <= m。

n < 0

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

n = 0

此时NUMBER表示整数。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  oracle 数据库