oracle 补齐数字长度 to_char踩坑

oracle的to_char网上找到的说明如下

(1)用作日期转换:

to_char(date,'格式');

复制代码
select to_date('2005-01-01 ','yyyy-MM-dd') from dual;
select to_char(sysdate,'yyyy-MM-dd HH24:mi:ss') from dual;

(2)处理数字:

to_char(number,'格式');

①其9代表:如果存在数字则显示数字,不存在则显示空格

②其0代表:如果存在数字则显示数字,不存在则显示0,即占位符。

③在格式参数FMT中,前面加上FM代表去掉返回结果中的前后空格和0。

复制代码
select to_char(88877) from dual;
select to_char(1234567890,'099999999999999')  from dual;
select to_char(12345678,'999,999,999,999')  from dual;
select to_char(123456,'99.999')  from dual;
select to_char(1234567890,'999,999,999,999.9999')  from dual;

(3)to_char(salary,'$99,99');

复制代码
 select TO_CHAR(123,'$99,999.9') from dual;

(4)用于进制转换:将10进制转换为16进制;

复制代码
select to_char(4567,'xxxx') from dual;
select to_char(123,'xxx') from dual;

使用场景:

定义了一个 循环sequence 用于与日期拼成一个唯一的序号。

使用to_char生成固定6位数的sequence

业务系统跑了一段时间后,发现序号的后6位变成######

这是什么情况,难道溢出了?我是循环sequence呀?

原来 to_char 对于超出占位符的数字全部显示#

解决办法1:用取余函数mod保证小于除数

解决办法2: lpad 不足左边补0,超出从左边开始截取,保证长度但是意义稍微有点差异。

办法3: 至少5位,从右到左截取5位

相关推荐
寒秋丶16 分钟前
Milvus:Json字段详解(十)
数据库·人工智能·python·ai·milvus·向量数据库·rag
ManageEngineITSM4 小时前
技术的秩序:IT资产与配置管理的现代重构
大数据·运维·数据库·重构·工单系统
档案宝档案管理6 小时前
档案宝:企业合同档案管理的“安全保险箱”与“效率加速器”
大数据·数据库·人工智能·安全·档案·档案管理
wangjialelele7 小时前
mysql库操作二
数据库·mysql
Chloeis Syntax7 小时前
MySQL初阶学习日记(1)--- 数据库的基本操作
数据库·学习·mysql
workflower7 小时前
FDD(Feature Driven Development)特征驱动开发
大数据·数据库·驱动开发·需求分析·个人开发
韩立学长8 小时前
基于Springboot的旧物公益捐赠管理系统3726v22v(程序、源码、数据库、调试部署方案及开发环境)系统界面展示及获取方式置于文档末尾,可供参考。
数据库·spring boot·后端
苦学编程的谢9 小时前
Redis_4_常见命令(完)+认识数据类型和编码方式
数据库·redis·缓存
小光学长9 小时前
基于Vue的儿童手工创意店管理系统as8celp7(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
前端·数据库·vue.js