从13位时间戳中取对应日期

最近项目中遇到一个小问题,在数据库存的时间戳为13位,我在MySQL只能转10位,而我想要的只是13位时间戳对应时间的日期:月-日。

在这里我用到了几个函数:

  1. ROUND() : 四舍五入(因为最后三位对应的是毫秒时间,向上向下取整没有实际作用,但是使用哪个都可以)
  2. FROM_UNIXTIME() : 将时间戳格式化  eg:2018-05-19 00:00:00
  3. 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一下,免得自己以后忘了。

猜你喜欢

转载自blog.csdn.net/wk950411/article/details/80374215