MySQL的Timestamp插入丢失毫秒的问题 - Go语言中文社区

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,就可以保存毫秒数了。

版权声明:本文来源CSDN,感谢博主原创文章,遵循 CC 4.0 by-sa 版权协议,转载请附上原文出处链接和本声明。
原文链接:https://blog.csdn.net/a_helloword/article/details/84714137
站方申明:本站部分内容来自社区用户分享,若涉及侵权,请联系站方删除。
  • 发表于 2020-06-27 20:44:46
  • 阅读 ( 1102 )
  • 分类:数据库

0 条评论

请先 登录 后评论

官方社群

GO教程

猜你喜欢