PostGresql四舍五入、小数转换、百分比用法

需求:两个整数相除,保留两位小数并四舍五入,完了转成百分比形式,即4/5=0.80=80%

1.两个整数相除:
idn_dw=> select 4/5;
 ?column?
----------
        0
(1 row)
在sql运算中,"/"意思是相除取整,这样小数部分就会被舍去。

2.用cast将被除数转成小数
idn_dw=> select cast(4 as numeric)/5;
        ?column?
------------------------
 0.80000000000000000000
(1 row)

也可以简化:pg中"::"转换的意思
idn_dw=> select 4::numeric/5;
        ?column?
------------------------
 0.80000000000000000000
(1 row)

3.四舍五入,保留两位小数
idn_dw=> select round(cast(4 as numeric)/5,2);
 round
-------
  0.80
(1 row)

4.放大100,转成百分比形式
idn_dw=> select concat(round(4::numeric/5,2)*100,'%');
 concat
--------
 80.00%
(1 row)
但是,小数部分不需要,调整一下顺序
idn_dw=> select concat(round(4::numeric/5*100),'%');
 concat
--------
 80%
(1 row)

完事。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值