Oracle的Trunc和round的区别

sql>select trunc(5.75), trunc(5.75,1), trunc(5.75,-1) from dual

  trunc(x [,y]),其中如果没有指定y,则对x在0位小数进行截断

Eg:TRUNC(5.75)=5,如果y是负数,则对x在小数点左边的第|y|位处进行截断

TRUNC(5.75, -1)=0,这里应对小数点左边的第|-1|位截取,为什么是0,不是5?

  另外ROUND函数是对数值进行取整.

Eg:Round(5.75)=6,表示对5.75在0位小数处进行取整四舍五入了?

  Round(5.75, 1)=5.8,这里第1位小数是5?取整进行了四舍五入?

ROUND(5.75, -1)=10,对5.75在左边第|-1|位取整,左边第一位就是十位?5是个位,是第0位?

  解答如下:

  第一个问题 如果y是负数,则对x在小数点左边的第|y|位处进行截断,例如:TRUNC(5.75, -1)=0 5.75 看成 0005.75.000 从小数点左边第一位往左边截,不是0吗

  第二个问题,例如:ROUND(5.75)=6,表示对5.75在0位小数处进行取整,这里0位小数是7? 0位小数是没有,不是7, 7是第一位小数了。5.75取整 就是6啊,是四舍五入了啊,要不 round和trunc就没区别了嘛。

  ROUND(5.75, 1)=5.8,这里第1位小数是5? 不是,第一位小数是7 四舍五入就是 5.8

  ROUND(5.75, -1)=10,对5.75在左边第|-1|位取整,左边第一位就是十位?小数点左边第一位是个位,你同样看成 00005.75000,从个位的左边开始取,并四舍五入。 个位是5 左边的十位是0,由于5是进1的,所以是10.

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值