【脚下留心】new Date插入数据库多一秒

背景

最近遇到一个坑,创建数据的时候,数据有效时间:new Date,然后响应后,立刻拿这个时间来反查,查不到数据

原因

在使用new Date() 插入数据库时,查询出来比实际多了一秒,mysql 表字段设置为datetime类型,当时间精确到秒时,如果毫秒大于500时,会自动进位。

测试

 public static SimpleDateFormat df = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss:SSS");
    public static void main(String[] args) throws InterruptedException {
        for (int i = 0; i < 8; i++) {
            System.out.println(df.format(new Date()));
            Thread.sleep(100);
        }

    }

在这里插入图片描述

解决方法

   /**
     * 解决Date存入数据库中毫秒>500时进一位。
     */
    public static Date nowDb() {
        Calendar calendar = Calendar.getInstance();
        calendar.set(Calendar.MILLISECOND, 0);
        return calendar.getTime();
        
    }
测试
public static SimpleDateFormat df = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss:SSS");
    public static void main(String[] args) throws InterruptedException {
        for (int i = 0; i < 8; i++) {
            System.out.println(df.format(nowDb()));
            Thread.sleep(100);
        }

    }

    /**
     * 解决Date存入数据库中毫秒>500时进一位。
     */
    public static Date nowDb() {
        Calendar calendar = Calendar.getInstance();
        calendar.set(Calendar.MILLISECOND, 0);
        return calendar.getTime();
        
    }


在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值