具有毫秒精度的时间戳:如何在MySQL中保存它们

时间:2014-10-10 12:11:03

标签: mysql datetime timestamp milliseconds

我必须使用MySQL开发一个应用程序,我必须保存像“1412792828893”这样的值,它们代表一个时间戳,但精度为毫秒。也就是说,自1970年1月1日以来的毫秒数。我将该行声明为timestamp,但不幸的是,这不起作用。所有值都设置为0000-00-00 00:00:00

CREATE TABLE IF NOT EXISTS `probability` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`segment_id` int(11) NOT NULL,
`probability` float NOT NULL,
`measured_at` timestamp NOT NULL,
`provider_id` int(11) NOT NULL,
PRIMARY KEY (`id`)
) ;

为了能够以这种精度保存时间戳值,声明应该如何?

3 个答案:

答案 0 :(得分:97)

您需要使用MySQL 5.6.4或更高版本来声明具有小数秒时间数据类型的列。不确定你的版本是否合适?试试SELECT NOW(3)。如果您收到错误消息,则说明版本不合适。

例如,DATETIME(3)会在时间戳中为您提供毫秒级的分辨率,而TIMESTAMP(6)将在* nix风格的时间戳上为您提供微秒分辨率。

阅读本文:https://dev.mysql.com/doc/refman/8.0/en/fractional-seconds.html

NOW(3)将以毫秒精度从MySQL服务器的操作系统中提供当前时间。

如果你有Unix epoch后的毫秒数,试试这个以获得DATETIME(3)值

FROM_UNIXTIME(ms * 0.001)
例如,

Javascript timestampsUnix epoch后的毫秒数表示。

(请注意,MySQL内部小数算术,如* 0.001,总是作为IEEE754双精度浮点处理,因此在太阳变成白矮星之前,你不太可能失去精度。 。)

如果您使用的是旧版MySQL,并且需要亚秒级时间精度,那么最佳途径就是升级。任何其他事情都会迫使你做一些凌乱的解决方法。

如果出于某种原因无法升级,您可以考虑使用BIGINTDOUBLE列来存储Javascript时间戳,就好像它们是数字一样。 FROM_UNIXTIME(col * 0.001)仍然可以正常运行。如果您需要当前时间存储在此列中,则可以使用UNIX_TIMESTAMP() * 1000

答案 1 :(得分:0)

您可以按以下方式使用BIGINT:

mvn versions:set -DnewVersion=2.0.0

答案 2 :(得分:0)

CREATE TABLE fractest( c1 TIME(3), c2 DATETIME(3), c3 TIMESTAMP(3) );

INSERT INTO fractest VALUES
('17:51:04.777', '2018-09-08 17:51:04.777', '2018-09-08 17:51:04.777');