我必须使用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 5.6.4或更高版本,才能声明具有小数秒时间数据类型的列。不确定您使用的版本正确吗?尝试SELECT NOW(3)
。如果遇到错误,则说明您的版本不正确。
例如,DATETIME(3)
将为您提供时间戳的毫秒分辨率,并TIMESTAMP(6)
为您提供* nix样式的时间戳的微秒分辨率。
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
问题内容: 我在Vala中编写一些代码,在那里我将首先获取系统时间,然后创建一个文件,然后检索该文件的时间戳。时间戳记总是早于系统时间,介于500到1500微秒之间,这没有任何意义。 然后,我编写了一个简单的shell脚本: 结果如下: 如您所见,小数点后的前3位(毫秒)似乎可以正常显示,因为它们正在按预期的顺序递增,但是第4位及其后的数字看起来不正确。倒数第4至9位似乎在变慢。我有什么理由吗,尽
有人能告诉我处理这个问题的文档吗?
我在代码中使用倒计时。问题是,倒计时不准确。onTick方法并不总是每秒执行一次,它可能需要几毫秒的时间。当试图基于millisUntilFinished执行某项任务时,这会成为一个问题。当我的20秒计时器超过10秒时,我正在尝试登录: 以下是相关代码: 这里出现了一个问题,因为countDownTimer可能永远不会有millisUntilFinished==10000,它可能等于1001,因此
本文向大家介绍lua中使用毫秒精度时间的方法,包括了lua中使用毫秒精度时间的方法的使用技巧和注意事项,需要的朋友参考一下 lua自带的时间函数只能到秒的精度。 为了统计到毫秒精度的时间,可以使用luasocket。下载地址http://files.luaforge.net/releases/luasocket/luasocket 编译安装的时候,你可能需要在源码包根目录下的config文件中指定
我需要使用格式“m-d-Y H:I:s.u”(包括毫秒)在laravel应用程序上以高精度的时间戳存储更新的_ 根据laravel文档,我可以通过在类上设置$dateFormat属性来自定义日期格式,但是。。。 主要问题是Laravel的模式生成器在数据库中添加了一列类型时间戳,当我使用$table- 有什么办法可以做到这一点吗?
我将MSSTAMP作为Oracle中的“毫秒时间戳”,格式:1483228800000。如何将该毫秒时间戳转换为日期格式“YYYY-MM”,以便计算前几年每月完成的行数。 我已经尝试了TO_DATE、CAST、TO_CHAR的不同变体——但我无法做到这一点。