Oracle number 类型转换为 varchar2「建议收藏」

Oracle number 类型转换为 varchar2「建议收藏」项目初期表结构设计是非常重要,在字段类型定义样也要格外小心,业务开展后,修改字段类型代价非常大。本文主要记录在oracle中number类型转换为varchar2数据类型方法以及案例演示。number类型的数据直接存人varchar2类型的字段中,会出现格式问题,如:.5,5.等to_char(number)可将number类型转换为varchar2类型,可以指定格式fmt(可选);参数n,可以是NUMBER、BINARY_FLOAT或BINARY_DOUBL

大家好,又见面了,我是你们的朋友全栈君。

项目初期表结构设计是非常重要,在字段类型定义样也要格外小心,业务开展后,修改字段类型代价非常大。本文主要记录在 oracle 中 number 类型转换为 varchar2 数据类型方法以及案例演示。
number类型的数据直接存人 varchar2类型的字段中,会出现格式问题,如:.5, 5. 等

to_char(number)

TO_CHAR(n [, fmt [, 'nlsparam' ] ])

  • 可将 number 类型转换为 varchar2 类型,可以指定格式 fmt(可选);
  • 参数n,可以是 NUMBER、BINARY_FLOAT 或 BINARY_DOUBLE 类型;
  • nlsparam 参数指定了数值格式的元素返回的字符:包括:小数点字符(d)、组分隔符(g)、本地货币符号、国际货币符号。

格式化修饰符 FM

  • 9: 代表如果存在数字则显示数字,不存在数字为空字符串(非FM格式则会补空格);
  • 0: 代表如果存在数字则显示数字,不存在数字则显示0;
  • 小数会做四舍五入处理,如果不想四舍五入,现将数据做 trunc 处理后,再转换格式;

注意点:

  • 转换整数需要注意末尾是否多了小数点;
  • 转换小于1的小数首位的0会丢失;
  • 数据长度大于 fmt 定义的长度,转换会发生异常;

基本用法


-- 9 不会补占位符
select to_char(123.45, 'FM9999.999') from dual;
-- ==>

-- 补占位符 0
select to_char(123.45, 'FM0000.000') from dual;
-- ==>0123.450

-- 四舍五入
select to_char(123.4567, 'FM9999.999') from dual;
-- ==>123.457
select length(to_char(123.4567, 'FM9999.999')) from dual;
-- ==> 7

整数格式化问题


select to_char(123, 'FM9999.999') from dual;
-- ==>123.

-- 解决方案1
select regexp_replace(to_char(123, 'FM9999.999'), '\.$', '') from dual;
-- ==>123
-- 解决方案2
select to_char(123, 'FM9999.099') from dual;
-- ==>123.0

小数格式化问题(小于1的数)

  • 建议格式化数值,如果不确定是整数,还是小于1的数,在小数点左右使用 0 作为占位符;

-- 小数格式化问题(小于1的数)
select to_char(0.123, 'FM9999.999') from dual;
-- ==>.123

-- 解决方法
select to_char(0.123, 'FM9990.999') from dual;
-- ==>0.123

数据太长导致的错误



-- 数据太长导致的错误:
select to_char(123.4567, 'FM99.9') from dual;
-- ==>#####

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/163906.html原文链接:https://javaforall.net

(0)
上一篇 2022年7月24日 上午11:00
下一篇 2022年7月24日 上午11:16


相关推荐

  • SAP与金税连接有两种方式:组件接口及文本接口。

    SAP与金税连接有两种方式:组件接口及文本接口。SAP与金税连接有两种方式:组件接口及文本接口。文本接口为例:1、SAP取发票数据,主要来自合同,销售订单,交货单,发票,客户供应商主数据等2、SAP处理:合并,拆分,折扣等3、导出TXT文本4、金税开票机读取文本:通过参数传递数据,注意1分钱误差问题(参数传递导致)5、回写收票方名称出具发票地址的增强BADI:IDGTCN_CUST_ADDR接口回传后将金税发票号回写对应的…

    2022年6月10日
    47
  • 信息熵、信息增益、信息增益比「建议收藏」

    信息熵、信息增益、信息增益比「建议收藏」信息熵“信息熵”是度量样本集合纯度最常用的一种指标。假定当前样本集合D中第k类样本所占的比例为pk(k=1,2,…,|y|),则D的信息熵定义为:Ent(D)的值越小,则D的纯度越高。如果上面的解释不容易理解,那么下面再通俗地解释一下:首先来看一下信息熵这个公式在数轴上的表示:可以看到,在概率为0.5的时候,信息熵是最大的(为1)。我们可以把信息熵理解为“不确定性”,当概率为0.5…

    2025年5月25日
    5
  • USB转RS485/RS422接线说明

    USB转RS485/RS422接线说明       

    2022年6月6日
    82
  • 数据库设计工具—–PD

    数据库设计工具—–PD数据库设计工具—–PDPowerDesign是一款功能强大的建模软件,提供强大的元数据管理功能,可以帮助用户构建关键信息的全方位视图,创建多种类型的模型,包括数据模型,物理模型,面向对象模型等等。同时继承了数据管理、BL、数据集成和数据整合多种功能。这是一款收费软件安装完成后,就来介绍一下基本使用。注意:这是一款功能非常非常非常强大的软件,我们只是介绍一下一小部分我们数据库用到的功能。进入软件后界面如下:我们点击file->然后创建一个model(模型)。然后创建一个物理

    2022年7月11日
    31
  • oracle 锁表 解锁 批量解锁[通俗易懂]

    oracle 锁表 解锁 批量解锁[通俗易懂]oracle锁表,解锁

    2022年6月17日
    42
  • win7关机命令_win7cmd关机命令

    win7关机命令_win7cmd关机命令通过DOS命令“shutdown”来实现Windows7系统下的定时关机功能。使用at命令at12:00shutdown-s,取消:at/deleteshutdown-s-t20-c

    2022年8月4日
    8

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号