MYSQL中如何让字段结果精确到小数点后两位数字

MYSQL中如何让字段结果精确到小数点后两位数字,第1张

可以在建表的时候限定小数点的长度,例如decimal(5,2),后面的2就是2位的意思。

如果表已经建好,可以在查询语句中用函数 round(X,2) 转换,X为字段,后面的数字为长度,你要几位就填几。

在mysql中,这种计算可用TIMESTAMPDIFF函数来解决,但是解决过程中需要将数据多次加工。

1、创建测试表及插入测试数据:

create table test

(time1 datetime,

time2 datetime)

insert into test values ('2015-04-03 17:01:09','2015-06-03 22:09:30')

2、目前要结算time2和time1的时间差,用如下语句:

select round(TIMESTAMPDIFF(second,time1,time2)/3600,2) from test

结果如图:

解读:

首先,先用

select TIMESTAMPDIFF(second,time1,time2) from test

来计算两个时间之间的秒数差。

然后,得到的结果除以3600,即为这两个时间之间的小时数。

最后因为要求保留2位小数,则通过round函数,四舍五入,取出2位小数即可。

一,数值类型保留小数点后两个0

在存入数据时,应客户需求数值类型,比如钱数,分数等等需要精确到小数点后几位。

800存入时显示为800.00

方法:在建表时直接定义此数值的类型为float,double或decimal类型

例如:

1 create tablenum(2 shuzi float(4,2),3 shuzi2 double(4,2),4 shuzi3 decimal(4,2)5 )

类型(a,b):a指定指定小数点左边和右边可以存储的十进制数字的最大个数,

b指定小数点右边可以存储的十进制数字的最大个数,小数位数必须是从 0 到 a之间的值。默认小数位数是 0。

此时在插入数据

1 insert into num values(22,33,44)

那么此时显示的数据就是:

22.00 33.00 44.00

无需手动输入00.

最后说一下

float:浮点型,含字节数为4,32bit,数值范围为-3.4E38~3.4E38(7个有效位 对最后一位数四舍五入)

double:双精度实型,含字节数为8,64bit数值范围-1.7E308~1.7E308(15个有效位 对最后一位数四舍五入 float和double的相乘 *** 作,数字溢出不会报错会有精度的损失)

decimal:数字型,128bit,不存在精度损失,常用于银行帐目计算。(28个有效位 当对decimal类型进行 *** 作时,数值会因溢出而报错)

二,在存入数据时存入整数,select 查询时取出带小数.00的数据

同样应客户需求,可能仅仅是因为美观而进行的 *** 作

在定义时定义的就为整形或者其它的数值类型那么在取数据时可以使用round()函数

见表并定义

1 create tablenum(2 shuzi int

3 )

插入数据

insert into num values(22)

取出数据

select round(shuzi,2) fromnum

或truncate(shuzi,2)

此时显示为22.00


欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/zaji/6131948.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-03-15
下一篇 2023-03-15

发表评论

登录后才能评论

评论列表(0条)

保存