当数字的精度被定为number(3,2)时, 这时他能输入的数字整数部分只能是3-2=1位, 小数位如果不够会用0补齐, 超出的四舍五入保留3位小数.

SQL> insert into t_te(num1) values(45.67882);
insert into t_te(num1) values(45.67882)
ORA-01438: 值大于为此列指定的允许精度

SQL> insert into t_te(num1) values(12.3);
insert into t_te(num1) values(12.3)
ORA-01438: 值大于为此列指定的允许精度

SQL> insert into t_te(num1) values(1.3);
1 row inserted

SQL> select num1 from t_te;
NUM1
-----
1.30


当数字的精度被定为number(3,0)时, 这时能输入的数字整数部分只能是小于5位的, 小数部分全部四舍五入, 只留下整数. 这种情况在给定义列的数据类型的时候会被系统默认成number(3).

SQL> insert into t_te(num2) values(123.45);
1 row inserted

SQL> select num2 from t_te;
NUM2
----
123

SQL> insert into t_te(num2) values(1234.45);
insert into t_te(num2) values(1234.45)
ORA-01438: 值大于为此列指定的允许精度

SQL> insert into t_te(num2) values(1.45);
1 row inserted

SQL> select num2 from t_te;
NUM2
----
123
1

SQL> insert into t_te(num2) values(1.89);
1 row inserted

SQL> select num2 from t_te;
NUM2
----
123
1
2


当数字的精度被定为number(2,3)时, 这时能输入的数字就只能是小数了, 而且只能是小数点后(3-2=1)位小数, 整数位不能有数字.

SQL> insert into t_te(num3) values(1.89);
insert into t_te(num3) values(1.89)
ORA-01438: 值大于为此列指定的允许精度

SQL> insert into t_te(num3) values(0.89);
insert into t_te(num3) values(0.89)
ORA-01438: 值大于为此列指定的允许精度

SQL> insert into t_te(num3) values(0.089);
1 row inserted

SQL> select num3 from t_te;
NUM3
----
0.08

当数字的精度被定为number(3,-2)时, 这时输入的数字可以是任何一个整数部分小于5(3-(-2))位, 小数部分随意的数字, 但是系统会四舍五入保留百位显示.

SQL> insert into t_te(num4) values(12.3456);
1 row inserted

SQL> insert into t_te(num4) values(122.3456);
1 row inserted

SQL> insert into t_te(num4) values(1222.3456);
1 row inserted

SQL> insert into t_te(num4) values(122234253524.3456);
insert into t_te(num4) values(122234253524.3456)
ORA-01438: 值大于为此列指定的允许精度

SQL> insert into t_te(num4) values(12223.3456);
1 row inserted

SQL> insert into t_te(num4) values(122236.3456);
insert into t_te(num4) values(122236.3456)
ORA-01438: 值大于为此列指定的允许精度

SQL> select num4 from t_te;
NUM4
-----
0
100
1200
12200


当数字的精度被定为number(2,-3)时, 这时能输入的数字只要整数部分不超过5(2-(-3))位, 都不会报错, 小数位会直接被四舍五入. 系统只显示整数部分

SQL> insert into t_te(num5) values(12345);
1 row inserted

SQL> insert into t_te(num5) values(12345723);
insert into t_te(num5) values(12345723)
ORA-01438: 值大于为此列指定的允许精度

SQL> insert into t_te(num5) values(123456);
insert into t_te(num5) values(123456)
ORA-01438: 值大于为此列指定的允许精度

SQL> insert into t_te(num5) values(12345.345678);
1 row inserted

SQL> select num5 from t_te;
NUM5
----
12000
12000

关于number...的精度问题的更多相关文章

  1. 【转】JS中处理Number浮点数精度问题

    https://github.com/dt-fe/number-precision ~(function(root, factory) { if (typeof define === "fu ...

  2. oracle SQL查询number字段精度丢失之解决方法

    解决办法: -- 3.3:表示原始数据 --fm9999999990.0000:表示保留到小数点后4位,若不存在则用0补位. ),'fm9999999990.0000') as demo from d ...

  3. hibernate NUMBER 精度

    通过Hibernate映射实体时会根据数据库中NUMBER类型的精度,生成相应的POJO类中相对应的主键类型.经过亲测结果如下: NUMBER(1) POJO类中生成的是Boolean publicc ...

  4. Oracle类型number与PG类型numeric对比和转换策略

    Oracle 11g number 任意精度数字类型 http://docs.oracle.com/cd/B28359_01/server.111/b28318/datatype.htm#CNCPT3 ...

  5. Oracle 数据库语句大全

    Oracle数据库语句大全 ORACLE支持五种类型的完整性约束 NOT NULL (非空)--防止NULL值进入指定的列,在单列基础上定义,默认情况下,ORACLE允许在任何列中有NULL值. CH ...

  6. 非常好的Oracle教程【转】

    http://www.blogjava.net/kiant/articles/234781.html Oracle 笔记(四).SQL 几个要点 附录: 1.SQL 简介 2.SQL 操作符 3.Or ...

  7. ORACLE常见数据类型详解

    1.字符类型 • CHAR:一个定长字符串,当位数不足自动用空格填充来达到其最大长度.如非NULL的CHAR(12)总是包含12字节信息.CHAR字段最多可以存储2,000字节的 信息. • VARC ...

  8. Oracle 常用数据类型(转)

    varchar2(6) 张三 --在jbk中是两个字节,在utm中是三个字节char(6) 张 三 --可以确定长度的用charclob --大存储,没事少用,当多余4000字节时,会用lob来存储, ...

  9. Oracle数据库字段类型说明

    目前Oracle 数据库大概有26个字段类型,大体分为六类,分别是字符串类型.数字数据类型.日期时间数据类型.大型对象(LOB)数据类型.RAW和LONG RAW数据类型.ROWID和UROWID数据 ...

随机推荐

  1. 【ActiveMQ入门-4】ActiveMQ学习-异步接收

    总体说明: 1. 一个生产者/发布者:可以向多个目的地发送消息: 2. 每个目的地(destination)可以有多个订阅者或消费者: 如下图所示: 程序结构: 1. Publisher.java   ...

  2. java web 中 页面/业务重定向

    情形一:地址栏简洁明了(列表页面需要局部查询,分页)  页面初始化:library方法,没有任何过滤条件,显示第一页: 页面刷新:library方法,page依旧保留,在地址栏中显示,但局部查询条件会 ...

  3. MySQL concat用法举例

    concat配合information_schema的应用 1    concat的一般用法主要是用于拼接 示例: 执行语句 SELECT CONCAT('M','y','S','Q','L') 可以 ...

  4. Linux之 AWK SED

    AWK系列#awk 中 NF表示取最后一列 NR表示取第几行 NR==3 表示取第三行[root@nodchen-db01-test ~]# free -m | awk 'NR==3 {print $ ...

  5. 解决IE下select标签innerHTML插入option的BUG(兼容

    在ie下面使用innerHTML来插入option选项的话,ie会去掉前面的<option>,并拆分成多个节点,这样会造成select的出错   前言: 这是一个老bug了,现在提供一个完 ...

  6. golang web框架 beego 学习 (一) 环境搭建

    下面的命令我都是在$GOPATH的路径下执行的: 1. 首先下载beego框架: go get github.com/astaxie/beego (注意:运行上面命令时没有反应,需要在etc/host ...

  7. pig入门案例

    测试数据位于:/home/hadoop/luogankun/workspace/sync_data/pigperson.txt中的数据以逗号分隔 ,zhangsan, ,lisi, ,wangwu, ...

  8. KDD 2018 | 最佳论文:首个面向Facebook、arXiv网络图类的对抗攻击研究

    8 月 19 日至 23 日,数据挖掘顶会 KDD 2018 在英国伦敦举行,昨日大会公布了最佳论文等奖项.最佳论文来自慕尼黑工业大学的研究者,他们提出了针对图深度学习模型的对抗攻击方法,是首个在属性 ...

  9. python之路之迭代器与生成器

    一  迭代器 那么在研究迭代器之前首先应该要知道什么是迭代. 迭代:是一个重复的过程,并且每次重复都是建立基于上一次的结果而来的,所以在迭代的过程其实是在不断变化的. 迭代器:就是迭代取值的工具. 那 ...

  10. bat批处理(二):%0 %1——给批处理脚本传递参数

    初次接触批处理脚本觉得有点意思,所以决定写一个小功能试验一下,谁知刚一开始就发现遇到了麻烦,本想着使用参数来控制程序的运行结果,可是参数怎么传进去呢,于是研究了一番,最终发现这个参数的传递与main函 ...