R+mongo的组合真是各种坑等着踩
由于mongo中的时间戳普遍使用的是unix timestamp的格式,因此需要对每天的数据进行计算的时候,很容易就想到对timestamp + gap对方式来实现每天的时间范围。
但这时候就埋下了一个坑,这个坑就是计算精度的问题。
ms级的时间戳长度是12位,R中会识别成1.421112+e12的格式。gap的则是 1000 * 60 * 60 *24 * i,数量级是10^8。两者相加,在取某个i的时候,会出现加出来的数据与下一天的timestamp对不上的情况。
在我的情况下,当i = 3的时候,就出现了这种异常。
关于计算精度的问题,感觉不应该只在R存在。其他脚本语言,在处理mongo按天递增的时候,也应该会碰到。
不过其他语言都有直接把时间转换成timestamp的函数,如果不是自己计算的gap,而是用toTimestamp(Date + 1)的方式去递增时间,则是不存在这个问题的。
由于R没有直接date2timestamp的函数,又下意识认为作为科学计算的R,应该会精确的处理数据的计算问题,所以没有防范。
时间: 2024-10-20 00:22:54