手头的问题如下: 1)从已经建立TCP/IP套接字连接的硬件接收Vax VMS 64位纪元时间,2)将Unix等效纪元时间存储到oracle数据库表中,3)允许用户在GUI上查询和显示这样的时间,使得日期格式是MM/DD/YYYY,并且时间格式是小数点右边有9位数字(如17:30:30.123456789)。
我已经成功地编写了代码,以建立到硬件的TCP/IP套接字连接并处理接收到的数据。
在互联网上搜索时,我发现了一篇文章,解释了如何将Vax VMS 64位纪元时间转换为Unix纪元时间。本文中的C函数如下:
void timevmstounix( long long *vmstimein, time_t *epochout )
{
long long timevalue = *vmstimein;
timevalue -= 0x07c95674beb4000ull;
timevalue /= 10000000;
*epochout = (time_t) timevalue;
return;
}通过额外的互联网研究,我的理解是,对应于long long和time_t C数据类型的Java数据类型(从Java8开始)是一个long。这是正确的吗?
我定义并构建了一个oracle数据库表,其中包含类型为timestamp(9)的列,以便能够检索小数点右侧9位数字的时间。
我遇到的最大的问题/困惑是,我如何将生成的Unix纪元时间存储在这个Oracle数据库列中,以便稍后当用户对相关的数据库表执行查询时,我可以用to_char(column_name,'MM/DD/YYYY HH24:MI:SS.sssssssss')查询这个列的内容,并以正确的所需格式显示它。感谢您能提供的任何帮助/建议/更正。
发布于 2015-12-23 08:28:41
也许这能行得通:
insert into <your_table> values( timestamp '1970-01-01 00:00:00 GMT' +
numtodsinterval(<your unix value>/1000, 'SECOND') )https://stackoverflow.com/questions/34426319
复制相似问题