mysql除法运算保留小数的用法

傷城~ 2022-05-17 11:55 318阅读 0赞

参照:https://www.cnblogs.com/owenma/p/7097602.html
在工作中会遇到计算小数而且需要显现出小数末尾的0,我们会用到DECIMAL这个函数,这是一个函数非常强悍:具体用法DECIMAL(P,D);
在上面的语法中:

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

与INT数据类型一样,DECIMAL类型也具有UNSIGNED和ZEROFILL属性。 如果使用UNSIGNED属性,则DECIMAL UNSIGNED的列将不接受负值。

如果使用ZEROFILL,MySQL将把显示值填充到0以显示由列定义指定的宽度。 另外,如果我们对DECIMAL列使用ZERO FILL,MySQL将自动将UNSIGNED属性添加到列。

测试案例:
数据库的表结构
这里写图片描述
这里写图片描述
第一种计算方式:

  1. select convert(t/100,decimal(15,2)) as money from test

这里写图片描述

  1. select convert(t/100,decimal(10,2)) as money from test

这里写图片描述

第二种计算方式
返回数字X,截断到D小数位。 如果D为0,结果没有小数点或小数部分。 D是负数,导致值X的小数点左边的D数字变为零。(简单说就是没有四舍五入)

  1. SELECT TRUNCATE(t/100,2) as g from test

这里写图片描述

  1. select convert(4545.1366,decimal(10,3));

这里写图片描述

发表评论

表情:
评论列表 (有 0 条评论,318人围观)

还没有评论,来说两句吧...

相关阅读

    相关 定点除法运算

    目录 一、原码除法运算 1.原码比较法和恢复余数法 ⑴比较法 ⑵恢复余数法 2.原码不恢复余数法(原码加减交替法) 二、补码除法运算 1、够减的判断