mysql timestamp毫秒_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 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语句,发现往数据库插入的时候还是有毫秒数的。

6030f3ffb8b7

16.png

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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值