oracle中number型字段长度、精度及实际存储状态测试

2024-02-26 08:48

本文主要是介绍oracle中number型字段长度、精度及实际存储状态测试,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

工作中经常要遇到这种字段的处理情况,当然以前也见过大虾总结过。但是看了之后,又还给人家。是人家的终究还是人家的,需要自己亲自测试并总结才能变成自己的。

相关知识回顾:
有效数位:从左边第一个不为0的数算起,小数点和负号不计入有效位数。
number(p,s)
      p:1~38
      s:-84~127
p>0,对s分2种情况:
1. s>0
        精确到小数点右边s位,并四舍五入。然后检验有效数位是否<=p;如果s>p,小数点右边至少有s-p个0填充。
2. s<0
        精确到小数点左边s位,并四舍五入。然后检验有效数位是否<=p+|s|

      案例测试:
hongsy@test>desc hongsy;
 名称                                                  是否为空? 类型
 ----------------------------------------------------- -------- ------------
 NUM1                                                           NUMBER
 NUM2                                                           NUMBER(2)
 NUM3                                                           NUMBER(5,3)
 NUM4                                                           NUMBER(5,-2)
hongsy@test>insert into hongsy(num1) values(1111111111);
已创建 1 行。
hongsy@test>commit;
提交完成。
hongsy@test>insert into hongsy(num2) values(11);
已创建 1 行。
hongsy@test>insert into hongsy(num2) values(111);
insert into hongsy(num2) values(111)
                                *
ERROR 位于第 1 行:
ORA-01438: 值大于此列指定的允许精确度

hongsy@test>insert into hongsy(num2) values(-11);
已创建 1 行。
hongsy@test>insert into hongsy(num2) values(-111);
insert into hongsy(num2) values(-111)
                                *
ERROR 位于第 1 行:
ORA-01438: 值大于此列指定的允许精确度

hongsy@test>insert into hongsy(num2) values(-11.1);
已创建 1 行。
hongsy@test>insert into hongsy(num2) values(-11.1111);
已创建 1 行。
hongsy@test>commit;
提交完成。
hongsy@test>select num2 from hongsy;
NUM2
----------

        11
       -11
       -11
       -11
已选择8行。
hongsy@test>insert into hongsy(num3) values(111);
insert into hongsy(num3) values(111)
                                *
ERROR 位于第 1 行:
ORA-01438: 值大于此列指定的允许精确度

hongsy@test>insert into hongsy(num3) values(11);
已创建 1 行。
hongsy@test>insert into hongsy(num3) values(-11);
已创建 1 行。
hongsy@test>insert into hongsy(num3) values(-111);
insert into hongsy(num3) values(-111)
                                *
ERROR 位于第 1 行:
ORA-01438: 值大于此列指定的允许精确度

hongsy@test>insert into hongsy(num3) values(11.111);
已创建 1 行。
hongsy@test>insert into hongsy(num3) values(11.1111);
已创建 1 行。
hongsy@test>commit;
提交完成。
hongsy@test>select num3 from hongsy;
NUM3
----------

        11
       -11
    11.111
    11.111
已选择12行。
hongsy@test>insert into hongsy(num4) values(1111);
已创建 1 行。
hongsy@test>insert into hongsy(num4) values(111111);
已创建 1 行。
hongsy@test>insert into hongsy(num4) values(11111111);
insert into hongsy(num4) values(11111111)
                                *
ERROR 位于第 1 行:
ORA-01438: 值大于此列指定的允许精确度

hongsy@test>commit;
提交完成。
hongsy@test>select num4 from hongsy;
NUM4
----------

      1100
    111100
已选择14行。
hongsy@test>insert into hongsy(num4) values(1111111);
已创建 1 行。
hongsy@test>commit;
提交完成。
hongsy@test>select num4 from hongsy;
NUM4
----------

      1100
    111100
   1111100
已选择15行。
hongsy@test>create table hongsy1 (num1 number(39));
create table hongsy1 (num1 number(39))
                                  *
ERROR 位于第 1 行:
ORA-01727: 数字精度说明符超出范围(1 到 38)

hongsy@test>create table hongsy1 (num1 number(38,128));
create table hongsy1 (num1 number(38,128))
                                     *
ERROR 位于第 1 行:
ORA-01728: 数字标度说明符超出范围(-84 到 127)

这篇关于oracle中number型字段长度、精度及实际存储状态测试的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


原文地址:
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.chinasem.cn/article/748297

相关文章

Nginx设置连接超时并进行测试的方法步骤

《Nginx设置连接超时并进行测试的方法步骤》在高并发场景下,如果客户端与服务器的连接长时间未响应,会占用大量的系统资源,影响其他正常请求的处理效率,为了解决这个问题,可以通过设置Nginx的连接... 目录设置连接超时目的操作步骤测试连接超时测试方法:总结:设置连接超时目的设置客户端与服务器之间的连接

oracle DBMS_SQL.PARSE的使用方法和示例

《oracleDBMS_SQL.PARSE的使用方法和示例》DBMS_SQL是Oracle数据库中的一个强大包,用于动态构建和执行SQL语句,DBMS_SQL.PARSE过程解析SQL语句或PL/S... 目录语法示例注意事项DBMS_SQL 是 oracle 数据库中的一个强大包,它允许动态地构建和执行

PLsql Oracle 下载安装图文过程详解

《PLsqlOracle下载安装图文过程详解》PL/SQLDeveloper是一款用于开发Oracle数据库的集成开发环境,可以通过官网下载安装配置,并通过配置tnsnames.ora文件及环境变... 目录一、PL/SQL Developer 简介二、PL/SQL Developer 安装及配置详解1.下

oracle如何连接登陆SYS账号

《oracle如何连接登陆SYS账号》在Navicat12中连接Oracle11g的SYS用户时,如果设置了新密码但连接失败,可能是因为需要以SYSDBA或SYSOPER角色连接,解决方法是确保在连接... 目录oracle连接登陆NmOtMSYS账号工具问题解决SYS用户总结oracle连接登陆SYS账号

Oracle数据库如何切换登录用户(system和sys)

《Oracle数据库如何切换登录用户(system和sys)》文章介绍了如何使用SQL*Plus工具登录Oracle数据库的system用户,包括打开登录入口、输入用户名和口令、以及切换到sys用户的... 目录打开登录入口登录system用户总结打开登录入口win+R打开运行对话框,输php入:sqlp

查询Oracle数据库表是否被锁的实现方式

《查询Oracle数据库表是否被锁的实现方式》本文介绍了查询Oracle数据库表是否被锁的方法,包括查询锁表的会话、人员信息,根据object_id查询表名,以及根据会话ID查询和停止本地进程,同时,... 目录查询oracle数据库表是否被锁1、查询锁表的会话、人员等信息2、根据 object_id查询被

Oracle查询优化之高效实现仅查询前10条记录的方法与实践

《Oracle查询优化之高效实现仅查询前10条记录的方法与实践》:本文主要介绍Oracle查询优化之高效实现仅查询前10条记录的相关资料,包括使用ROWNUM、ROW_NUMBER()函数、FET... 目录1. 使用 ROWNUM 查询2. 使用 ROW_NUMBER() 函数3. 使用 FETCH FI

数据库oracle用户密码过期查询及解决方案

《数据库oracle用户密码过期查询及解决方案》:本文主要介绍如何处理ORACLE数据库用户密码过期和修改密码期限的问题,包括创建用户、赋予权限、修改密码、解锁用户和设置密码期限,文中通过代码介绍... 目录前言一、创建用户、赋予权限、修改密码、解锁用户和设置期限二、查询用户密码期限和过期后的修改1.查询用

Oracle数据库使用 listagg去重删除重复数据的方法汇总

《Oracle数据库使用listagg去重删除重复数据的方法汇总》文章介绍了在Oracle数据库中使用LISTAGG和XMLAGG函数进行字符串聚合并去重的方法,包括去重聚合、使用XML解析和CLO... 目录案例表第一种:使用wm_concat() + distinct去重聚合第二种:使用listagg,

Python 中 requests 与 aiohttp 在实际项目中的选择策略详解

《Python中requests与aiohttp在实际项目中的选择策略详解》本文主要介绍了Python爬虫开发中常用的两个库requests和aiohttp的使用方法及其区别,通过实际项目案... 目录一、requests 库二、aiohttp 库三、requests 和 aiohttp 的比较四、requ