您需要使用MySQL 5.6.4或更高版本,才能声明具有小数秒时间数据类型的列。不确定您使用的版本正确吗?尝试
SELECtNOW(3)。如果遇到错误,则说明您的版本不正确。
例如,
DATETIME(3)将为您提供时间戳的毫秒分辨率,并
TIMESTAMP(6)为您提供* nix样式的时间戳的微秒分辨率。
- 阅读此内容:https
- //dev.mysql.com/doc/refman/8.0/en/fractional-
seconds.html
NOW(3)将为您提供MySQL服务器操作系统的当前时间(以毫秒为单位)。
如果自Unix纪元以来有毫秒数,请尝试此操作以获取DATETIME(3)值
FROM_UNIXTIME(ms * 0.001)
例如,自Unix纪元以来,以毫秒为单位表示Javascript时间戳。
(请注意,MySQL内部小数运算(如
* 0.001)始终被视为IEEE754双精度浮点数,因此,在太阳成为一颗白矮星之前,您不太可能会失去精度。)
如果您使用的是旧版MySQL,并且需要亚秒级的时间精度,则最好的方法是升级。其他任何事情都将迫使您执行混乱的解决方法。
如果由于某种原因而无法升级,则可以考虑使用
BIGINT或
DOUBLE列将Javascript时间戳当作数字来存储。
FROM_UNIXTIME(col * 0.001)仍然可以正常工作。如果您需要当前时间存储在这样的列中,则可以使用
UNIX_TIMESTAMP()* 1000



