SQL中两个数字相除,结果保留n位小数

需求:MySQL两字段相除,得出结果保留n位小数(多表自己联合查询)


SQL函数大全及示例汇总
MySQL 函数

函数描述
round(c,decimals)对数值c进行decimals位小数位数的四舍五入
convert()格式化日期和数值,它需要两个参数:第1个是源数据,第2个是目标数据类型

新建了个测试表,先上表在这里插入图片描述
方式一:

select a, b, round(if(a=0,0,a*1.0/b),4) rate from test

在这里插入图片描述

先乘以1.0,此时数据会变成double类型,然后double类型去除以一个整数,结果还是double类型。后面的4表示保留几位小数。

方式二:

select convert(a/b,decimal(15,4)) as rate from test

在这里插入图片描述

decimal(P,D)表示列可以存储D位小数的P位数。十进制列的实际范围取决于精度和刻度。
P是表示有效数字数的精度。 P范围为1〜65。
D是表示小数点后的位数。 D的范围是0~30。MySQL要求D小于或等于(<=)P。

以上得出结果相同:
在这里插入图片描述
效率上因为个人数据量不大,有兴趣的童鞋可以测试一手

  • 0
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值