【Neo4j】关于NodeMatcher(NodeMatch)结合Relationship创建Relation失败问题

一、问题描述

        在使用Neo4j构建知识图谱的时候,网上有非常多使用NodeMatcher或NodeMatch来获得相应的Node(实体),并且使用Relationship来建立Node(实体)之间的联系。如:

def __init__(self,url,username,password,data_path,sheet_name):
    # 打开数据库
    self.url = url
    self.username = username
    self.password = password
    self.graph = Graph(self.url,auth = (self.username,self.password))
def Create_Relationship(self):
     Nodes = NodeMatcher(self.graph)
    url = 'D014024'
    next_url = 'D005088'
    Current_Node = Nodes.match(current_label,Unique_ID=url)
    Next_Node = Nodes.match(next_label, Unique_ID=next_url)
    Relation = Relationship(Current_Node,"link",Next_Node)
    self.graph.create(Relation)

       网上的解决方法如下:

1、增加first():

Current_Node = Nodes.match(current_label,Unique_ID=url).first()
Next_Node = Nodes.match(next_label, Unique_ID=next_url).first()

2、 修改筛选格式:

Current_url = "_.Unique_ID=" + "\"" + url + "\""
Current_Node = Nodes.match(current_label).where(Current_url)
Next_url = "_.Unique_ID=" + "\"" + next_url + "\""
Next_Node = Nodes.match(next_label).where(Next_url)

         但是上述方法都没有办法解决问题。

二、问题解决

        使用Run函数,借用Cypher语言创建Relation:

url = 'D014024'
next_url = 'D005088'
current_label = self.level_one + 'level' + str(i)
next_label = self.level_one + 'level' + str(i+1)
Relation = "MATCH (from:"+current_label+"{Unique_ID:"+"\""+url+"\""+"}),(to:"+next_label +"{Unique_ID:"+"\""+next_url+"\""+"}) MERGE (from)-[r:link]->(to)"
self.graph.run(Relation)

         问题解决!

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值