oracle 补齐数字长度 to_char踩坑
2024-01-07 19:18:31
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位
文章来源:https://blog.csdn.net/fonjames/article/details/135420333
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。 如若内容造成侵权/违法违规/事实不符,请联系我的编程经验分享网邮箱:veading@qq.com进行投诉反馈,一经查实,立即删除!
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。 如若内容造成侵权/违法违规/事实不符,请联系我的编程经验分享网邮箱:veading@qq.com进行投诉反馈,一经查实,立即删除!