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位

相关推荐
2301_796588502 分钟前
Go语言如何压缩文件_Go语言gzip压缩教程【基础】
jvm·数据库·python
m0_617881424 分钟前
c++如何通过重定向rdbuf来捕获第三方库的日志输出到文件【详解】
jvm·数据库·python
IntMainJhy5 分钟前
【flutter for open harmony】第三方库Flutter 国际化多语言的鸿蒙化适配与实战指南
数据库·flutter·华为·sqlite·harmonyos
Greyson113 分钟前
mysql查询执行过程中如何追踪耗时_使用PROFILE分析指令周期
jvm·数据库·python
解救女汉子18 分钟前
CSS如何实现水平垂直居中效果_利用flex布局的justify-content与align-items
jvm·数据库·python
2301_7735536219 分钟前
CSS如何解决栅格重叠问题_使用Grid-area明确划分元素占位
jvm·数据库·python
看海的四叔21 分钟前
【SQL】SQL的日期与时间函数
数据库·hive·sql·数据分析·时间函数·日期函数
步辞25 分钟前
JavaScript中Symbol-keyFor检索全局符号键名逻辑
jvm·数据库·python
瀚高PG实验室27 分钟前
磁盘故障导致数据库进入恢复模式
数据库·瀚高数据库
Irene199127 分钟前
EXTRACT 是 Oracle 中的一个日期/时间提取函数,也会导致索引失效(和 TO_CHAR() 对比)
oracle·extract