zoukankan      html  css  js  c++  java
  • java代码中和mysql数据库中时间相差1秒问题?

    mysql数据库的时间总是比代码中的时间多一秒。
      @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));//舍去毫秒
            }
        }

    可以更具上边代码自己测试,查看结果。

    思路:时间如果毫秒多余500,存到mysql总是会多出一秒的时间。所以这个我们在代码中用到时间的时候。

    时间格式化
    SimpleDateFormat df = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
    这样子拿到的时间就是去掉了毫秒的数据值,但是存到mysql中的时间是
     Date date0 = new Date();
    这个可是没有去掉毫秒的,所以数据库就给我们四舍五入了,导致我们数据库中的时间比代码中的时间多一秒。

    所以为了获取到准确的时间,我们在使用时间的时候,就需要自己斟酌了。
  • 相关阅读:
    一次有教益的程序崩溃调试 (中)
    读书:手工测试与自动测试
    迭代还是交付?
    用Windbg调试.NET程序的资源泄漏
    一次有教益的程序崩溃调试 (上)
    基于云计算的软件测试服务
    Vcastr 3.0 api
    学习Linux三(Linux常用命令及技巧)
    学习Linux六(Linux必学60个命令之【文件处理】)
    学习Linux四(Linux必学60个命令)
  • 原文地址:https://www.cnblogs.com/renjianjun/p/14214487.html
Copyright © 2011-2022 走看看