首页 > 代码库 > postgresql中to_char和round的混合使用

postgresql中to_char和round的混合使用

在postgresql中大家都用过round吧,当遇到小数的时候该如何显示呢?看例子

SELECT to_char(round(127 * 0.1 / 67543,6)*10000,‘90.99‘)

1.88

SELECT to_char(round(127 * 0.1 / 67543,6)*10000,‘90.00‘)

1.88

SELECT to_char(round(150 * 0.1 / 50000,6)*1000,‘90.09‘)

0.30

SELECT to_char(round(150 * 0.1 / 50000,6)*1000,‘00.09‘)

00.30

SELECT to_char(round(150 * 0.1 / 50000,6)*1000,‘99.09‘)

.30

看出规则了没?呵呵,以上sql的结果说明:0是任意占位符,如果0位上有数据那就显示数据,如果没有数据就显示0;9是实数占位符,9位上有数据(大于0 的数),显示数据,没有数据则什么也不显示。

所以当我们要取百分数或千分数的时候,要满足xx.xx的格式时,就要用90.99当占位符

postgresql中to_char和round的混合使用