原文:The World’s Most Amazing Python Driver for Neo4j
作者:Nigel Small
译者:仲培艺,关注数据库领域,纠错、寻求报道或者投稿请致邮:zhongpy@csdn.net。
尽管Neo4j社区目前已发布了Java、Python、JavaScript和.NET官方支持的驱动程序,但其发展并未停步。本周,Neo4j发布驱动程序py2neo3.1版本,同时还为Python用户推出了全新的OGM。
OGM(Object-Graph Mapper)和图形数据库的关系,就相当于ORM(对象关系映射)和传统RDMS之间的关系:前者都是一个架构,可供构建database-aware领域对象(domain objects)。
Py2neo OGM的操作围绕新的GraphObject类展开。此处其扮演基础类和管理者的双重角色:前者限定了领域对象;后者则支持基础节点和使py2neo OGM持久化的相关平台。
借Movie Graph(和Neo4j预先打包)为例,以该数据集为基础,模拟一个Person类:
classPerson(GraphObject):
__primarykey__ = "name"
name =Property()born =Property()
此处,一个Person类有两类属性。而Neo4j的属性没有固定类型,因此,比起典型ORM下的SQL字段,其相关定义较少。
类属性和基础属性名称相同:命名和生成。必要时,其可重定向为不同名属性,含表达式例如Property(name="actual_name")。
最终,定义一个主键(primarykey),指出哪种属性是push和pull操作的唯一标识符;定义一个primarylabel,尽管是默认条件,仍可用Person代替。
综上所述,可以通过一个Cypherstatement,挑选出一个特定Person对象节点:
MATCH (a:Person) WHEREa.name = {n}RETURNa
此外,如果想要在同一个数据集内,模拟Person和Movie,还有其关联平台,可通过以下途径:
classMovie(GraphObject): __primarykey__ ="title"title =Property() tagline =Property() released =Property() actors = RelatedFrom("Person","ACTED_IN") directors = RelatedFrom("Person","DIRECTED") producers = RelatedFrom("Person","PRODUCED")classPerson(GraphObject): __primarykey__ ="name"name =Property() born =Property() acted_in = RelatedTo(Movie) directed = RelatedTo(Movie) produced = RelatedTo(Movie)
此处包含两类新属性:RelatedTo和RelatedFrom。这两类属性定义了关系对象集(连接方式相似)。换句话说,就是它们共享相同的开始节点或终止节点,和共同的关系类型。
以acted_in = RelatedTo(Movie)为例,它描述了一组Movie关系节点集,这些节点都是通过一个输出ACTED_IN关系来连接的。这里要注意的是,和上面提及的属性命名一样,关系类型也默认自动匹配属性名,只不过此处字母为大写形式。相反,对应的反向定义,actors = RelatedFrom("Person", "ACTED_IN")则明指定了关系名,以区分与属性名的差异。
为了研究执行对象的方法,可以假设一个情境:需要从数据库中提取出Keanu Reeves,并将他和经典影片Bill & Ted’s Excellent Adventure相连接 (不包含在原始图当中)。在这种情况下,首先要利用GraphObject类,并通过Person子类选择演员。随后,构建一个新的Movie对象,并添加到Keanu Reeves参与演出的影片集当中。最终,将上述全部信息汇入图表中。进程代码如下:
keanu= Person.select(graph,"Keanu Reeves").first()bill_and_ted = Movie()bill_and_ted.title="Bill & Ted's Excellent Adventure"keanu.acted_in.add(bill_and_ted)graph.push(keanu)
通过一个类似集的端口(提供添加和移除方法),关系对象支持其父类对象。这些数据汇入图表之后,为了完成操作,OGM架构自动构建并运行所有必要的Cypher。
该方法也可用于执行其它更复杂的选择。Where
method可利用所有WHERE
子句中的expression。比如要输出所有名字首字母是“K”的演员,操作如下:
forpersoninPerson.select(graph).where("_.name =~ 'K.*'"):print(person.name)
注意:此处用到下划线字符来指代待匹配节点。
Py2neo文档还包含很多其它信息,且GitHub知识库当中还有一个演示应用程序,该程序展示了一个微型movie浏览器(截图如下)当中,一切是如何运行的。
2016年8月12日-13日,由CSDN重磅打造的互联网应用架构实战峰会、运维技术与实战峰会将在成都举行,目前18位讲师和议题已全部确认。两场峰会大牛讲师来自阿里、腾讯、百度、京东、小米、乐视、聚美优品、YY、华为、360等知名互联网公司,共同探讨高可用/高并发/高性能系统架构设计、电商架构、分布式架构、运维工具研发与实践、运维自动化系统的构建、大数据与运维、云上的运维案例分析、虚拟化技术、应用性能检测与管理、游戏行业的运维实践等,将和与会嘉宾共同探讨「构建更安全、更高性能、更稳定的架构和运维体系」等领域的话题与技术。【目前限时6折,点击这里抢票】
7月15日24点前仍处于最低六折优惠票价阶段,单场峰会(含餐)门票只需499元,5人以上团购或者购买两场峰会通票更有特惠,限时折扣,预购从速。(票务详情链接)。
网友评论