一起学习网 一起学习网


MySQL的四舍五入规则及其自动处理方式(mysql自动四舍五入)

网络编程 MySQL的四舍五入规则及其自动处理方式(mysql自动四舍五入) 10-17

MySQL的四舍五入是指在进行数值类型数据计算时,根据规则:大于等于0.5则进位,小于0.5则舍去.这是MySQL中早就有的标准,但新版本可以自定义规则,可以更调整精度。

MySQL的四舍五入规则是服务器端处理数值计算时使用的一种算法,主要处理近似值或者取整数值的时候使用,主要的操作有向上取整和向下取整,sql语句体现为round()及 truncate()。

向上取整指的是,当一个数值刚好到达特定的精度时,就自动加一,将其变成更高的精度的值,常用的表达式为:

“`sql

SELECT ROUND(1.150,2); +————–+ | ROUND(1.150,2)| +————–+ | 1.15| +————–+


这里,1.15四舍五入了,结果是1.15.

向下取整指的是,当一个数值刚好到达特定的精度时,就自动减一,将其变成更低的精度的值,常用的表达式为:

```sql
SELECT TRUNCATE(1.150,2); +----------------+ | TRUNCATE(1.150,2)| +----------------+ | 1.14| +----------------+

这里,1.15取整了,结果是1.14.

MySQL新版本的引入了改进的四舍五入模式,允许开发人员能够自定义自动处理方式。ROUND()语句有一个可选的第三个参数mode,可以设置的数值只有0、1和-1,每一个数值代表了不同的四舍五入模式:

* mode参数为0,代表采用传统方式舍入,即四舍五入,这是MySQL默认的模式

* mode参数为1,代表始终向上取整,即只进位不舍去

* mode参数为-1,代表始终向下取整,即只舍去不进位

开发人员可以根据实际项目需求,来更改取值的规则:

“`sql

SELECT ROUND(1.145,2,1); +———————-+ | ROUND(1.145,2,1) | +———————-+ | 1.15| +———————-+


这里,1.145始终向上取整,结果是1.15.

带有mode参数的ROUND()语句使我们可以轻松自定义四舍五入,对于如何调整精度等问题更加灵活,且处理数据精度要比常规方法更加方便。

回顾以上,MySQL的四舍五入模式是服务器端处理数值计算时使用的一种算法;主要操作有向上取整和向下取整,sql语句分别体现为round()及 truncate();MySQL新版本的引入了改进的四舍五入模式,允许开发人员能够自定义自动处理方式。可以根据所设置参数mode,高效解决计算精度问题。

编辑:一起学习网

标签:精度,数值,四舍五入,自定义,参数