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

### 如何在Java中生成仅包含年月日的时间 在Java中,可以通过`SimpleDateFormat`类来格式化日期对象并提其中的年、月、日部分。以下是具体方法: #### 使用 `SimpleDateFormat` 提年月日 通过设置模式为 `"yyyy-MM-dd"` 的 `SimpleDateFormat` 对象,可以将 `Date` 类型的数据转换成仅包含年月日的字符串形式[^1]。 ```java import java.text.SimpleDateFormat; import java.util.Date; public class Main { public static void main(String[] args) { Date currentDate = new Date(); SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd"); String formattedDate = sdf.format(currentDate); System.out.println(formattedDate); // 输出形如:2023-10-07 } } ``` 上述代码展示了如何利用 `SimpleDateFormat` 将当前时间转化为仅含年月日的形式。 #### 转换回时间 如果需要将该日期重新转为时间,则需先解析字符串再获其毫秒值。注意此过程会丢失小时分钟秒钟的信息,因此最终得到的是当天零点对应的时间[^4]。 ```java try { Date parsedDate = sdf.parse(formattedDate); long timestamp = parsedDate.getTime(); // 获自1970年以来的毫秒数 System.out.println(timestamp); } catch (Exception e){ e.printStackTrace(); } ``` 以上两段代码共同实现了从原始时间到仅有年月日表示再到新时间的过程。 ### 注意事项 当处理大量数据或者性能敏感场景下,频繁实例化 `SimpleDateFormat` 可能带来一定开销,建议采用线程安全的方式比如 `DateTimeFormatter` 来替代它(适用于更高版本JDK环境)[^3]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值