java代码中和mysql数据库中时间相差1秒问题?

转载:淡淡人生过

数据库给我们四舍五入了,导致我们数据库中的时间比代码中的时间多一秒
    @org.junit.Test
    public void ttt() throws InterruptedException
    {
        SimpleDateFormat df = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss:SSS");

        for (int i = 0; i < 10; i++)
        {
            Thread.sleep(100);
            final Date date0 = new Date();
            Date date1 = DateUtils.round(date0, Calendar.SECOND);
            Date date2 = DateUtils.ceiling(date0, Calendar.SECOND);
            Date date3 = DateUtils.truncate(date0, Calendar.SECOND);
            final Timestamp timestamp = Timestamp.valueOf(
                    new SimpleDateFormat("yyyy-MM-dd HH:mm:ss", Locale.SIMPLIFIED_CHINESE).format(date0)
            );
            System.out.println("new Date() =============================================>"+ date0 + "  " + df.format(date0));
            System.out.println(" org.apache.commons:commons-lang3:3.8.1 .DateUtils.round " + date1+ "  " + df.format(date1));
            System.out.println(" org.apache.commons:commons-lang3:3.8.1 .DateUtils.ceiling " + date2+ "  " + df.format(date2));
            System.out.println(" org.apache.commons:commons-lang3:3.8.1 .DateUtils.truncate " + date3+ "  " + df.format(date3)); //舍去毫秒
            System.out.println("timestamp==================================================>"+timestamp+ "  " + df.format(timestamp));//舍去毫秒
        }
    }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值