【问题标题】:Neo4j LOAD CSV cannot match and create relationshipsNeo4j LOAD CSV 无法匹配和创建关系
【发布时间】:2018-12-10 03:27:08
【问题描述】:

我正在浏览 LOAD CSV 电影示例中的教程示例,同时将其应用于我的项目的测试数据。 (我正在尝试遵循此处的示例代码: https://neo4j.com/docs/getting-started/current/cypher-intro/load-csv/)

我正在尝试在每篇文章的关键字之间建立关系,然后找到具有相同关键字的其他文章。

我的测试数据 csv 文件的表示如下: 用于创建所有标题节点的 CSV:

title_id,title  
T1,Article Title 1  
T2,Article Title 2  

我想用来创建关系的 CSV:

title_id,keyword_id,keyword  
T1,K1,aaa  
T1,K2,bbb  
T1,K3,ccc  
T1,K4,ddd  
T2,K1,aaa  
T2,K5,eee  
T2,K6,fff  
T2,K4,ddd  

首先,我尝试使用以下代码创建标题节点:

LOAD CSV WITH HEADERS FROM "file:///1209_tet_titles.csv" AS csvLine1
WITH csvLine1
WHERE csvLine1.title_id IS NOT NULL
MERGE (a_title:title{t_id:csvLine1.title_id,Title:csvLine1.title})

然后,我尝试使用以下代码在关系旁边创建单个关键字节点:

LOAD CSV WITH HEADERS FROM "file:///1209test_titleid_kwid_kw.csv" AS csvLine3
WITH csvLine3
WHERE csvLine3.title_id IS NOT NULL
MERGE(keywords:Keyword{k_id:csvLine3.keyword_id,Keyword:csvLine3.keyword})
WITH csvLine3
MATCH(title:Title{id:csvLine3.title_id}),(keyword:Keyword{id:csvLine3.keyword_id)})
CREATE (title)-[r1:HAS_KEYWORDS]->(keyword)

节点创建成功,但是 match 命令什么也没找到,因此没有创建任何关系。在这个阶段,我不确定我的情况和电影示例之间有什么区别......

【问题讨论】:

    标签: neo4j cypher


    【解决方案1】:

    这里看起来只是一个小错字。

    在您的 MERGE 中,您正在合并 k_id 属性,但在您的 MATCH 中,您正在匹配一个不存在的 id 属性。如果您将其更改为k_id,那么您应该会看到它成功。

    也就是说,无需重新匹配您刚刚创建的节点,因为您可以将变量保留在范围内并在创建关系时使用它:

    LOAD CSV WITH HEADERS FROM "file:///1209test_titleid_kwid_kw.csv" AS csvLine3
    WITH csvLine3
    WHERE csvLine3.title_id IS NOT NULL
    MERGE (keyword:Keyword{k_id:csvLine3.keyword_id, Keyword:csvLine3.keyword})
    WITH csvLine3, keyword
    MATCH (title:Title{t_id:csvLine3.title_id})
    CREATE (title)-[:HAS_KEYWORDS]->(keyword)
    

    【讨论】:

    • 很好,看来我犯了同样的错误!查询已修复。
    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多