最近项目中遇到一个小问题,在数据库存的时间戳为13位,我在MySQL只能转10位,而我想要的只是13位时间戳对应时间的日期:月-日。
在这里我用到了几个函数:
- ROUND() : 四舍五入(因为最后三位对应的是毫秒时间,向上向下取整没有实际作用,但是使用哪个都可以)
- FROM_UNIXTIME() : 将时间戳格式化 eg:2018-05-19 00:00:00
- DATE_FORMAT() : 取想要的时间
下面是取用户生日日期(月-日)
birthday = 1526659200000;
# 13位时间戳转10位 birthday/1000 ROUND(birthday/1000)
# 时间戳转 年-月-日 时:分:秒 FROM_UNIXTIME(ROUND(birthday/1000)) SELECT FROM_UNIXTIME(ROUND(birthday/1000));
# 格式化为 月-日 DATE_FORMAT(FROM_UNIXTIME(ROUND(birthday/1000)),'%m-%d') SELECT DATE_FORMAT(FROM_UNIXTIME(ROUND(birthday/1000)),'%m-%d') AS 生日;
SELECT DATE_FORMAT(FROM_UNIXTIME(ROUND(birthday/1000)),'%m-%d') AS 生日 FROM table_name WHERE DATE_FORMAT(FROM_UNIXTIME(ROUND(birthday/1000)),'%m-%d') = DATE_FORMAT(NOW(),'%m-%d')Mark一下,免得自己以后忘了。