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

SQL中两个数字相除,结果保留n位小数需求 MySQL 两字段相除 得出结果保留 n 位小数 多表自己联合查询 SQL 函数大全及示例汇总 MySQL 函数 函数 描述 round c decimals 对数值 c 进行 decimals 位小数位数的四舍五入 convert 格式化日期和数值 它需要两个参数 第 1 个是源数据

大家好,我是讯享网,很高兴认识大家。

需求: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。

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

小讯
上一篇 2025-01-28 21:18
下一篇 2025-03-17 16:58

相关推荐

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容,请联系我们,一经查实,本站将立刻删除。
如需转载请保留出处:https://51itzy.com/kjqy/124982.html