MySQL的Timestamp插入丢失毫秒的问题

昨天写项目的时候,因为加密的时候涉及到了数据库的一个timestamp类型的字段,写到后面发现生成的密文和接收到的密文死活对不上,唉。

今天吃完午饭看了看,写了个测试方法,

    @Test
    public void testAddUser() throws Exception {
        User user = new User();
        
        user.setAppOpenid("openId1");
        user.setSessionKey("sessionKey");
        user.setName("我是nic发kName");
        user.setNameSearch(SearchUtils.getSearchText("我是nic发kName"));
        user.setWeixinNickname("nickName");
        user.setSex(1);
        user.setAddress("江苏省南京市江宁区");
        Date date = new Date();
        Timestamp ts = new Timestamp(date.getTime());
        user.setCreateTime(ts);
        user.setHeaderTimestamp(date.getTime() / 1000);
        // 随机生成盐值
        int salt = LoginUtils.getSalt();
        user.setSalt(salt);
        user.setLastTime(ts);
        
        int nums = userDao.addUser(user);
        logger.info("nums = " + nums);
        
        Map<String, Object> map = userDao.selectSaltAndLastTime(user.getuId());
        
        System.out.println("map = " + map);
        System.out.println("ts = " + ts);
        System.out.println("map.last_time = " + map.get("last_time"));
    }

上面的方法主要是先把当前时间转换成java.sql.Timestamp类型,然后插入一条记录,接着获取刚刚插入的记录,发现从数据库查询出来的last_time和当前时间竟然对不上。难怪密文一直对不上。

map = {salt=1870360469, last_time=2018-12-02 14:39:32}
ts = 2018-12-02 14:39:32.91
map.last_time = 2018-12-02 14:39:32

看看打印出来的sql语句,发现往数据库插入的时候还是有毫秒数的。

16.png

看看数据库,发现毫秒数没了。再看看数据库的表字段属性,发现timestamp的长度设置为0。问题就出在这了,只需要把timestamp字段的长度设置为3,就可以保存毫秒数了。

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • ORA-00001: 违反唯一约束条件 (.) 错误说明:当在唯一索引所对应的列上键入重复值时,会触发此异常。 O...
    我想起个好名字阅读 5,494评论 0 9
  • 转 # https://www.cnblogs.com/easypass/archive/2010/12/ 08/...
    吕品㗊阅读 9,876评论 0 44
  • 20190102 感赏孩子今天准时上补习课,感赏孩子今天来外婆家时面带微笑,感赏孩子注重外表,自己去剪头发,感赏孩...
    清风淡云1阅读 137评论 1 2
  • 从小一起长大,没有想过分开,结果天各一方,没有预想的爱情,开花结果。变得平行的时空里,各自努力的工作、生活,但我已...
    狮子音阅读 231评论 0 0
  • 我因为所谓的给对方留全面子,自己随意臆想,导致我差多错过了一个学习的机会!我们不需要打破砂锅问到底,但是更不应该主...
    串_7c37阅读 224评论 0 0