解决数据插入到mysql时,多出一秒的问题

是否有朋友发现一个小问题,插入到到mysql的时间,会多出一秒

比如:当创建时间是2020-04-25 22:30:50,插入mysql,发现时间为2020-04-25 22:30:51

如果要求时间非常精确的系统,这肯定是不允许的,那么发生这个问题的原因是什么?

这是因为mysql的数据类型为datetime

当创建时间是2020-04-25 22:30:50.771,毫秒被四舍五入为2020-04-25 22:30:51

解决方案

将mysql时间类型改为datetime(3)

其实很简单,将数据库字段中datetime长度从0调整至3即可。

问题原因

因为Java的Date类对象获取的时间是以带着小数的毫秒数传入数据库的,而当数据库datetime设置长度为0时,会自动根据毫秒数后面的小数进行四舍五入,会导致时间精度的缺失。当把数据库字段的长度设置为3时,数据库则会保留毫秒数的三位小数,则不会导致时间精度的丧失。这个问题小会引起时间校正的不准确,大则到生成的密钥无法准确校验,所以不可忽视。

你可能感兴趣的:(mysql,数据库,java)