是否有朋友发现一个小问题,插入到到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时,数据库则会保留毫秒数的三位小数,则不会导致时间精度的丧失。这个问题小会引起时间校正的不准确,大则到生成的密钥无法准确校验,所以不可忽视。