首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >我想显示后面有2个数字的百分比。例如12.23

我想显示后面有2个数字的百分比。例如12.23
EN

Stack Overflow用户
提问于 2017-01-17 19:59:45
回答 2查看 32关注 0票数 0

我已经这样做了,但它返回给我一个数字,例如12.2536,而实际上我想要12.25.

代码语言:javascript
运行
复制
select njesia_adm ,
       v2003,
       t_2003,
       (cast ( v2003 as decimal) )/ cast( t_2003 as decimal )* 100  as decimal 

从哪里投票qarku='X'

EN

回答 2

Stack Overflow用户

发布于 2017-01-17 20:06:21

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

舍入到小数点后s位

请参阅PostgreSQL Documentation

票数 3
EN

Stack Overflow用户

发布于 2017-01-17 20:47:19

这样做的一个好方法是使用cast()函数,但在除法之后强制转换值:

代码语言:javascript
运行
复制
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标准函数。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/41696568

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档