news 2026/3/27 11:23:08

Neo4j查询语句写法举例

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Neo4j查询语句写法举例

Neo4j查询语句写法举例

# -*- coding: utf-8 -*-frompy2neoimportGraph,Node,Relationship,NodeMatcher#版本说明:Py2neo v4classNeo4j_Handle():graph=Nonematcher=Nonedef__init__(self):print("Neo4j Init ...")defconnectDB(self):self.graph=Graph("bolt: // localhost:7687",username="neo4j",password="zhangzl")self.matcher=NodeMatcher(self.graph)#实体查询,用于命名实体识别:品牌+车系+车型defmatchEntityItem(self,value):answer=self.graph.run("MATCH (entity1) WHERE entity1.name = \""+value+"\" RETURN entity1").data()returnanswer#实体查询defgetEntityRelationbyEntity(self,value):#查询实体:不考虑实体类型,只考虑关系方向answer=self.graph.run("MATCH (entity1) - [rel] -> (entity2) WHERE entity1.name = \""+value+"\" RETURN rel,entity2").data()if(len(answer)==0):#查询实体:不考虑关系方向answer=self.graph.run("MATCH (entity1) - [rel] - (entity2) WHERE entity1.name = \""+value+" \" RETURN rel,entity2").data()print(answer)returnanswer#关系查询:实体1deffindRelationByEntity1(self,entity1):#基于品牌查询answer=self.graph.run("MATCH (n1:Bank {name:\""+entity1+"\"})- [rel] -> (n2) RETURN n1,rel,n2").data()#基于车系查询,注意此处额外的空格if(len(answer)==0):answer=self.graph.run("MATCH (n1:Serise {name:\""+entity1+" \"})- [rel] - (n2) RETURN n1,rel,n2").data()returnanswer#关系查询:实体2deffindRelationByEntity2(self,entity1):#基于品牌answer=self.graph.run("MATCH (n1)<- [rel] - (n2:Bank {name:\""+entity1+"\"}) RETURN n1,rel,n2").data()if(len(answer)==0):#基于车系answer=self.graph.run("MATCH (n1) - [rel] - (n2:Serise {name:\""+entity1+" \"}) RETURN n1,rel,n2").data()returnanswer#关系查询:实体1+关系deffindOtherEntities(self,entity,relation):answer=self.graph.run("MATCH (n1:Bank {name:\""+entity+"\"})- [rel:Subtype {type:\""+relation+"\"}] -> (n2) RETURN n1,rel,n2").data()returnanswer#关系查询:关系+实体2deffindOtherEntities2(self,entity,relation):print("findOtherEntities2==")print(entity,relation)answer=self.graph.run("MATCH (n1)- [rel:RELATION {type:\""+relation+"\"}] -> (n2:Bank {name:\""+entity+"\"}) RETURN n1,rel,n2").data()if(len(answer)==0):answer=self.graph.run("MATCH (n1)- [rel:RELATION {type:\""+relation+"\"}] -> (n2:Serise {name:\""+entity+" \"}) RETURN n1,rel,n2").data()returnanswer#关系查询:实体1+实体2(注意Entity2的空格)deffindRelationByEntities(self,entity1,entity2):#品牌 + 品牌answer=self.graph.run("MATCH (n1:Bank {name:\""+entity1+"\"})- [rel] -> (n2:Bank{name:\""+entity2+" \"}) RETURN n1,rel,n2").data()if(len(answer)==0):#品牌 + 系列answer=self.graph.run("MATCH (n1:Bank {name:\""+entity1+"\"})- [rel] -> (n2:Serise{name:\""+entity2+" \"}) RETURN n1,rel,n2").data()if(len(answer)==0):#系列 + 品牌answer=self.graph.run("MATCH (n1:Serise {name:\""+entity1+"\"})- [rel] -> (n2:Bank{name:\""+entity2+" \"}) RETURN n1,rel,n2").data()if(len(answer)==0):#系列 + 系列answer=self.graph.run("MATCH (n1:Serise {name:\""+entity1+"\"})- [rel] -> (n2:Serise{name:\""+entity2+" \"}) RETURN n1,rel,n2").data()returnanswer#查询数据库中是否有对应的实体-关系匹配softdeffindEntityRelation(self,entity1,relation,entity2):answer=self.graph.run("MATCH (n1:Bank {name:\""+entity1+"\"})- [rel:subbank {type:\""+relation+"\"}] -> (n2:Bank{name:\""+entity2+"\"}) RETURN n1,rel,n2").data()if(len(answer)==0):answer=self.graph.run("MATCH (n1:Bank {name:\""+entity1+"\"})- [rel:subbank {type:\""+relation+"\"}] -> (n2:Serise{name:\""+entity2+"\"}) RETURN n1,rel,n2").data()if(len(answer)==0):answer=self.graph.run("MATCH (n1:Serise {name:\""+entity1+"\"})- [rel:subbank {type:\""+relation+"\"}] -> (n2:Bank{name:\""+entity2+"\"}) RETURN n1,rel,n2").data()if(len(answer)==0):answer=self.graph.run("MATCH (n1:Serise {name:\""+entity1+"\"})- [rel:subbank {type:\""+relation+"\"}] -> (n2:Serise{name:\""+entity2+"\"}) RETURN n1,rel,n2").data()returnanswer
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/3/25 0:45:46

六西格玛培训实战:光伏车间良率94%到98%的突破路径

凌晨两点&#xff0c;我亲手砸了车间那台电子秤。银浆桶底刮出的38克浆料&#xff0c;每年省258万——但栅线波动导致效率损失2400万。我们总在“看得见的节约”里精打细算&#xff0c;却在“看不见的损失”上一掷千金。这是合肥某光伏厂的真实故事。四个月前&#xff0c;我们组…

作者头像 李华
网站建设 2026/3/17 7:35:53

16、游戏优化与第三方服务集成

游戏优化与第三方服务集成 1. 游戏优化 在游戏开发过程中,优化是提升游戏体验的关键环节。以下是一些具体的优化操作: 1.1 场景与事件监听 为了实现场景切换和游戏逻辑的推进,我们添加了事件监听器。例如,添加了跳过事件监听器,以便切换到海盗湾场景,同时还为帧进入事…

作者头像 李华
网站建设 2026/3/15 8:46:45

31、Shell脚本编程:条件判断、整数运算与用户交互

Shell脚本编程:条件判断、整数运算与用户交互 1. 脚本退出状态与函数返回值 在脚本编写中,确保操作符后总是跟有字符串是很重要的,即便字符串为空。脚本结尾处常出现的 exit 命令可接受一个可选参数,该参数将作为脚本的退出状态。若未传递参数,退出状态默认值为0。借助…

作者头像 李华
网站建设 2026/3/16 9:11:46

17、网络操作与文件搜索实用指南

网络操作与文件搜索实用指南 1. 查看网络路由表 使用 netstat -r 命令可以显示内核的网络路由表,它展示了网络如何配置以在不同网络之间发送数据包。例如: [me@linuxbox ~]$ netstat -r Kernel IP routing table Destination Gateway Genmask Flags MSS W…

作者头像 李华
网站建设 2026/3/24 12:22:34

XGW-9000 网关 DDR4/LPDDR4 内存子系统信号完整性仿真细化设计

&#x1f4ca; XGW-9000 网关DDR4/LPDDR4 信号完整性仿真细化设计 一、DDR4/LPDDR4 系统级仿真架构 1.1 多负载拓扑结构仿真 # DDR4_Multi_Rank_Simulation.py # DDR4双Rank/多颗粒系统级仿真import siwave import pandas as pd import numpy as npclass DDR4SystemSimulator:d…

作者头像 李华