首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >Neo4j:将字符串转换为日期时间

Neo4j:将字符串转换为日期时间
EN

Stack Overflow用户
提问于 2022-07-27 10:23:24
回答 2查看 188关注 0票数 0

我将数据加载到Neo4j实例中,在该实例中,对于每个节点,我将时间信息记录在属性键(.time)中,格式如下:

YYYY MM-DD

示例:time: 1937-01-01

这些都是字符串,我想将它们转换为datetime,以便在Neo4j Bloom和各种基于时间的查询中使用它们。我尝试使用以下公式(以及它的各种变体):

代码语言:javascript
运行
复制
MATCH (p:Image)
WHERE p.time IS NOT NULL
SET p.time = datetime({ epochMillis: apoc.date.parse(p.time, 's', 'yyyy-MM-dd HH:mm:ss') })

但没有成功。我总是会犯错误

代码语言:javascript
运行
复制
Failed to invoke function `apoc.date.parse`: Caused by: java.text.ParseException: Unparseable date: "1891-01-01"

知道我做错了什么,以及如何将日期转换为字符串到日期时间吗?

我以前读过一些关于这个问题的帖子,但我找不到满意的答案.

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2022-07-27 10:39:07

您的数据格式与在apoc函数中指定的格式不匹配。另外,您可能需要解析毫秒,而不是秒,因为您使用的是epochMillis字段。

试试这个:

代码语言:javascript
运行
复制
MATCH (p:Image)
WHERE p.time IS NOT NULL AND p.time <> ""
SET p.time = datetime({ epochMillis: apoc.date.parse(p.time + " 00:00:00", 'ms', 'yyyy-MM-dd HH:mm:ss') })

好的,那么对于您的错误,您将不得不使用您以前的格式,并将您的日期转换为您的格式。这个错误基本上意味着毫秒分量不存在。

票数 1
EN

Stack Overflow用户

发布于 2022-07-27 10:33:11

如果只有日期部分而没有时间,则可以使用函数date()。您可以直接调用date('2015-07-21')

https://neo4j.com/docs/cypher-manual/current/functions/temporal/#functions-date-create-string

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/73136238

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档