cypher操作图数据库

文章讲述了如何在Neo4j的Cypher查询中使用变量,特别是当涉及到属性匹配时,以及如何处理Node对象的哈希性问题以实现去重。还介绍了Bolt协议的应用和查询示例。
摘要由CSDN通过智能技术生成

简单示例

sql语法

  • 在Match语法中,无法关系使用$引入变量(案例中的max_path_len)。如果一定要引入,就使用format的字符串占位符方法。
  • 在Match语法中,允许节点的属性使用$引入变量。
  • 如果sql已经使用了format格式,由于节点属性是用{}括起来的,f占位符也是用{}括起来,未避免冲突,对属性值需要使用双{},如f"xxx (a:Company {{name:$name}})-[*…{max_path_len}]-()"。

返回值

  • 返回值类型type(results) = <class ‘py2neo.cypher.Cursor’>,可迭代列表里的每个元素type(result) = <class ‘py2neo.cypher.Record’>。
  • 通过 result['属性名']的方式获取对应sql return里各个对象值。
  • 节点Node对象默认是不可哈希的,而set要求元素是可hash的,所以即使两个Node对象有相同的属性,它们也被视为是不同的对象,导致不能直接使用set(nodes)去重。
from py2neo import Graph

# database_url = "http://localhost:7474"
database_url = "bolt://localhost:7687"
database_username = "neo4j"
database_password = "neo4jcf"

# Bolt是Neo4j专门为图数据库设计的高性能网络协议,它是二进制的,比HTTP协议更快、更轻量级。
graph = Graph(database_url, auth=(database_username, database_password))

# 查询的最大路径长度
max_path_len = 3


def has_duplicates(nodes: tuple):
    # 由于Node对象默认是不可哈希的,而set要求元素是可hash的,所以即使两个Node对象有相同的属性,它们也被视为是不同的对象,导致不能直接使用set(nodes)去重。
    name_set = set(node["name"] for node in nodes)
    return len(nodes) != len(name_set)

### 方案一:在节点中指定属性
cypher_query = f"""
     MATCH path=(a:Company {{name:$name}})-[*..{max_path_len}]-(b:Company)
     RETURN path
     """

### 方案二:在where中指定属性
# cypher_query = f"""
#         MATCH path=(a:Company)-[*..{max_path_len}]-(b:Company)
#         where a.name=$name
#         RETURN path
#         """

### 一种:
results = graph.run(cypher_query, parameters={"name": "企业A"})
### 二种:
# results = graph.run(cypher_query, name="企业A")
print(f"type(results) = {type(results)}")  # type(results) = <class 'py2neo.cypher.Cursor'>

for result in results:
    '''
    path的值示例:
      Path(Node('Company', name='企业A', risk='否'), 工作单位(Node('Company', name='企业A', risk='否'), Node('Person', name='人A')), 认识(Node('Person', name='人A'), Node('Person', name='人B')), 董事(Node('Person', name='人B'), Node('Company', name='企业B', risk='是')))
    其中,type(result) = <class 'py2neo.cypher.Record'>
    '''
    path = result["path"]
    nodes = path.nodes  # 获取路径中的所有节点,type(nodes)=tuple
    # 这个路径中没有重复的节点
    if not has_duplicates(nodes):
        print(path)
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值