如果表已经建好,可以在查询语句中用函数 round(X,2) 转换,X为字段,后面的数字为长度,你要几位就填几。
SET @num1 := 10.1SET @num2 := 2
SELECT CONCAT(SUBSTRING_INDEX(@num1, '.', 1), '.', SUBSTR(CAST(@num1*100 AS SIGNED), -2)) AS num1,CONCAT(SUBSTRING_INDEX(@num2, '.', 1), '.', SUBSTR(CAST(@num2*100 AS SIGNED), -2)) AS num2
在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条)