关闭

关于Oracle将小于1的数字to_char后丢掉0的解决办法

101人阅读 评论(0) 收藏 举报
分类:

SQL代码如下:

select rtrim(to_char(0.11'fm9990.99'), '.'from dual;
其中
0.11为需要to_char的数字 
fm去掉字符串前面的空格
9990.99表示6位数字,千位百位十位无数字时不显示[标识9],个位数[标识0]永久显示,小数没有不显示[标识9]
如果数字位数超过4位则返回结果为####[符号#的个数由原字符串长度决定,比如:12345.01则返回8个#号]
此时需要增加格式化位数以达到目的[如:9999999990.99,表示最大10位整数]
如果需要永久显示两位小数,则用9990.00进行格式化
rtrim(str, '.') 去掉右侧的小数点符号[用于没有小数的整数]

具体规则可以参考 我的 “Oracle 类型转换参考
0
0

查看评论
* 以上用户言论只代表其个人观点,不代表CSDN网站的观点或立场
    个人资料
    • 访问:6863次
    • 积分:110
    • 等级:
    • 排名:千里之外
    • 原创:1篇
    • 转载:19篇
    • 译文:0篇
    • 评论:1条
    文章分类
    文章存档