我想用2个数字显示百分比。例如12.23

时间:2017-01-17 11:59:45

标签: sql

我已经做过的就是这个,但它给了我一个数字,例如12.2536,而实际上我想要12.25

select njesia_adm ,
       v2003,
       t_2003,
       (cast ( v2003 as decimal) )/ cast( t_2003 as decimal )* 100  as decimal 

来自qarku='X'

的投票

2 个答案:

答案 0 :(得分:3)

您可以使用“round(v numeric,s int)”函数。

  

舍入到小数位数

请参阅PostgreSQL Documentation

答案 1 :(得分:0)

执行此操作的一种好方法是使用cast()函数,但在除法之后转换值

select njesia_adm,
       v2003,
       t_2003,
       (cast( v2003 * 100.0 / t_2003 as decimal(5, 2)) as val

因为这会更改列的类型,应用程序也会理解只有两个小数位。因此,您不会看到12.2300等结果,因为应用程序要显示4位小数。

注意:这应该适用于所有数据库,因为decimal()是ANSI标准数据类型,cast()是ANSI标准函数。