毫秒精度的时间戳:如何将其保存在MySQL中


81

我必须使用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`)
) ;

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


什么版本的MySQL?
草莓

适用于Win32(x86)的mysql Ver 14.14 Distrib 5.6.11
Luixv 2014年

看起来你很幸运。
草莓

在插入之前,您手中的值是否以毫秒为单位?如果是这样,为什么不直接存储为BIGINT?
桑德曼2014年

Answers:


136

您需要使用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纪元以来有毫秒数,请尝试执行此操作以获取DATETIME(3)值

FROM_UNIXTIME(ms * 0.001)

例如,自Unix时代以来,以毫秒为单位表示Javascript时间戳

(请注意,MySQL内部小数运算(如* 0.001)始终被视为IEEE754双精度浮点数,因此在Sun成为一颗白矮星之前,您不太可能会失去精度。)

如果您使用的是旧版MySQL,并且需要亚秒级的时间精度,则最好的方法是升级。其他任何事情都将迫使您执行混乱的解决方法。

如果由于某种原因而无法升级,则可以考虑使用BIGINTDOUBLE列将JavaScript时间戳当作数字来存储。 FROM_UNIXTIME(col * 0.001)仍然可以正常工作。如果您需要当前时间存储在此类列中,则可以使用UNIX_TIMESTAMP() * 1000


我已将定义更改为timestamp(6),但是当尝试使用此语法添加值INSERT INTO概率(measured_at,概率,provider_id,segment_id)VALUES(1412877161519,0.7418073347680607,1,211623); 在“ measured_at”列中,我仍然得到注册00:00:00.00000。我应该如何在此表中插入值?
Luixv 2014年

1
@Luixv,您将需要按以下方式转换值:INSERT ... VALUES(FROM_UNIXTIME(0.001 * 1412877161519), 0.7418 ... );
Michael-sqlbot,2014年

乘以0.001可以节省生命!我永远猜不到它不会失去第二个分数。谢谢。
帕维尔·S.

就我而言,由于我正在使用树莓派进行测试(并且mysql 5.6在RPI中安装确实很麻烦,因此我要将信息保存为unix时间。)
silgon

0

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

CREATE TABLE user_reg (
user_id INT NOT NULL AUTO_INCREMENT,
identifier INT,
phone_number CHAR(11) NOT NULL,
verified TINYINT UNSIGNED NOT NULL,
reg_time BIGINT,
last_active_time BIGINT,
PRIMARY KEY (user_id),
INDEX (phone_number, user_id, identifier)
   );

但是,BIGINT是8个字节。有没有更有效的方法?这就像每个记录两个字节比你需要的
S.小鬼

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');
By using our site, you acknowledge that you have read and understand our Cookie Policy and Privacy Policy.
Licensed under cc by-sa 3.0 with attribution required.