从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一下,免得自己以后忘了。

  • 1
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值