解决oracle中0开头的小数,0消失的问题

问题复现:

今天在开发的过程中,遇到这种情况

然后又去oracle数据库里,查看一番,发现数据库寸的是0.9,这个零竟然离奇消失了。

原因

为何小数点前0会省略,是因为Oracle数据库中存在一个隐形类型转换,在拼接的过程中小数自动转成字符类型,相当于调用了to_char函数,所以丢失小数点前面的0

解决方式一:

加上to_char(字段,’fm9999999999999990.00’) ,(查看表结构设计,我这里类型是number(16,2),所以设置前面小数点前面最多16位,后面保留2位)

解释:

其中9代表如果存在数字则显示数字,不存在则显示空格; 0代表如果存在数字则显示数字,不存在则显示0,即占位符; fm代表删除如果是因9带来的空格,则删除。

解决方式二:

decode(SUBSTR(字段,1,1),.,0||字段,字段) 字段别名

解释:

截取值,如果开头是 小数点,那么加个0然后拼接上字段,如果不是,不做改变即可。

总结:

处理的办法有很多,当然能解决问题就可以

经验分享 程序员 微信小程序 职场和发展