Neo4j-Cypher语言语法

梦飞扬
2018-03-15
264 阅读

本文是记录Neo4j图数据库中实用的Cypher语言语法。

Cypher是什么

“Cypher”是一个描述性的类Sql的图操作语言。相当于关系数据库的Sql,可见其重要性。其语法针对图的特点而设计,非常方便和灵活。

  • Cypher是一个申明式查询语言,适合于开发者和在数据库上做点对点模式(ad-hoc)查询。
  • Cypher通过一系列不同的方法和建立于确定的实践为表达查询而激发的。许多关键字如
  • like和order by是受SQL的启发。正则表达式匹配实现模仿Scala 语言。


    学好Cypher是学好Neo4j的关键,也是核心所在!

Cypher语法

Create

CREATE (erzi:Person {id:‘erzi’}), //erzi是别名
(baba:Person {id:'baba'}),
(yeye:Person {id:'yeye',name:'zhangsan'}),
(nainai:Person {id:'nainai'}),
(mama:Person {id:'mama'}),
(bozi:Person {id:'bozi'}),
// 创建关系
(erzi)-[:fathor]->(baba),
(baba)-[:fathor]->(yeye),
(baba)-[:mother]->(nainai),
(erzi)-[:mother]->(mama),
(erzi)-[:girlFrend]->(bozi)

Match


match

相当于sql中的select

MATCH (n:Person) RETURN n limit 25

等价于:

Select * from Person limit 25

Merge


merge

相当于Match or Create 有则match,无则Create

MERGE (n:Person { name: 'Ann' }) RETURN n

下面这两条语句的对比?

match (n:Person {id:'mama'}),(m:Person {id:'nainai'}) merge (n)-[:poxi]->(m) return n,m

match (n:Person {id:'mama'}) with n match (m:Person {id:'nainai'}) merge (n)-[:poxi]->(m) return n,m

Delete 和 Remove

DELETE和REMOVE主要区别 :


DELETE操作用于删除节点和relation。


REMOVE操作用于删除标签label和属性。


Remove label 等同于drop table


两个命令都应该与MATCH命令一起使用。

Match (n:Person {id:'baba'}) remove n.age return n
MATCH (s:Teacher)-[r:teach]->(d:Student) delete r,s,d //删除与该关系相关的老师和学生及label
MATCH (n:Test) remove n:Test //删除label

如何仅仅删除一个relation?

Match (a:Person),(b:Person) where a.id='erzi' and b.id='bozi' merge (a)-[r:FUQI]->(b) DELETE r

order by


order by

同sql

Limit 和 Skip


limit

:显示多少行



skip

:从最前面开始,跳过多少行

Union 和 Union all


Union

:把多段Match的return结果 上线组合成一个结果集,会自动去掉重复行;



Union all

:作用同union,但不去重;

MATCH (n:Person) where n.age>20 RETURN n.id,n.age
union all
MATCH (n:Person) where n.id='erzi' RETURN n.id,n.age

In

和sql的区别就是使用[]中括号,而不是()括弧号

MATCH (n:Person) where n.age>20 RETURN n.id,n.age union all MATCH (n:Person) where n.id in ['erzi','bozi','baba'] RETURN n.id,n.age

Cypher 索引

create index on:Person(id)
drop index on:Person(id)

注意:

  • 创建索引时不需要给索引起名称,只需要设置索引的字段即可
  • 通过该字段的查询都走索引 where in =

唯一约束 Constraint

给某个属性设置唯一约束

create constraint on (n:Person) assert n.id is unique
drop constraint on (n:Person) assert n.id is unique

执行计划 explain

类似sql

常用函数

Neo4j无 group by


  • UPPER

    它用于将所有字母更改为大写字母。

  • LOWER

    它用于将所有字母改为小写字母。

  • SUBSTRING

    它用于获取给定String的子字符串。

  • REPLACE

    它用于替换一个字符串的子字符串。


    Match (n:Person) return SUBSTRING(n.id,2,0),n.id


聚集函数


  • COUNT

    它返回由MATCH命令返回的行数。

  • MAX

    它从MATCH命令返回的一组行返回最大值。

  • MIN

    它返回由MATCH命令返回的一组行的最小值。

  • SUM

    它返回由MATCH命令返回的所有行的求和值。

  • AVG

    它返回由MATCH命令返回的所有行的平均值。


    Match (n:Person) return count(*)


    Match (n:Person) return avg(n.age) 只包含age不为空的node


查询最短路径

查询最短路径的必要性:6层关系理论:任何两个事物之间的关系都不会超过6层。


关系链路越短,代表这两个节点的关系越密切!


allShortestPaths

[*..n] 用于表示获取n层关系,显示所有的链路关系(Single shortest path)



shortestPath

显示最短的链路(Single shortest path)


match p=allshortestPaths((n:Person {id:'mama'})-[*..3]-(b:Person {id:'nainai'})) return pmatch p=shortestPath((n:Person {id:'mama'})-[*..3]-(b:Person {id:'nainai'})) return p

-

本文是记录Neo4j图数据库中实用的Cypher语言语法。

posted @
2019-08-12 15:47 
星朝 
阅读(...) 
评论(...) 
编辑 
收藏

Neo4j-Cypher语言语法的更多相关文章

  1. neo4j初次使用学习简单操作-cypher语言使用

    Neo4j 使用cypher语言进行操作 Cypher语言是在学习Neo4j时用到数据库操作语言(DML),涵盖对图数据的增删改查  neo4j数据库简单除暴理解的概念: Neo4j中不存在表的概念, ...

  2. Neo4j Cypher语法(三)

    目录 5 函数 5.1 谓词函数 5.2 标量函数 5.3 聚合函数 5.4 列表函数 5.5 数学函数 5.6 字符串函数 5.7 Udf与用户自定义函数 6 模式 6.1 索引 6.2 限制 7 ...

  3. Neo4j数据和Cypher查询语法笔记

    Cypher数据结构 Cypher的数据结构: 属性类型, 复合类型和结构类型 属性类型 属性类型 Integer Float String: 'Hello', "World" B ...

  4. Go语言语法汇总(转)

    Go语言语法汇总 分类: 技术2013-09-16 14:21 3007人阅读 评论(0) 收藏 举报 go语言golang并发语法   目录(?)[+]   最近看了看GoLang,把Go语言的语法 ...

  5. C语言语法笔记 – 高级用法 指针数组 指针的指针 二维数组指针 结构体指针 链表 | IT宅.com

    原文:C语言语法笔记 – 高级用法 指针数组 指针的指针 二维数组指针 结构体指针 链表 | IT宅.com C语言语法笔记 – 高级用法 指针数组 指针的指针 二维数组指针 结构体指针 链表 | I ...

  6. R语言语法基础二

    R语言语法基础二 重塑数据 增加行和列 # 创建向量 city = c("Tampa","Seattle","Hartford"," ...

  7. R语言语法基础一

    R语言语法基础一 Hello world #这里是注释 myString = "hello world" print(myString) [1] "hello world ...

  8. L脚本语言语法手冊 0.10版

    L脚本语言语法手冊 0.10版       简  介 L脚本语言是一个轻量级的,旨在接近自然语言的编程语言,眼下支持在中文.英文基础上的编程.并可扩展为随意语种.L脚本语言的语法结构简单.程序结构相对 ...

  9. 嵌入式C语言自我修养 01:Linux 内核中的GNU C语言语法扩展

    1.1 Linux 内核驱动中的奇怪语法 大家在看一些 GNU 开源软件,或者阅读 Linux 内核.驱动源码时会发现,在 Linux 内核源码中,有大量的 C 程序看起来“怪怪的”.说它是C语言吧, ...

随机推荐

  1. (转)protobuf-----Mac 机器安装

    转自: https://blog.csdn.net/u014534808/article/details/80203018 安装之旅 1. 下载protobufprotobuf下载页面 在此页面选择合 ...

  2. mysql连接超时的问题处理

    1. 内网 ts 连接mysql 有时候会连接失败, 原因是 连接超时, 当时所有服务器一起启动,抢占资源,导致连接超过10s. 现在增加一次连接机会, 增加一些日志. 2. 并且对mysql 全局参 ...

  3. PHP算法之Z 字形变换

    将一个给定字符串根据给定的行数,以从上往下.从左到右进行 Z 字形排列. 比如输入字符串为 "LEETCODEISHIRING" 行数为 3 时,排列如下: L C I RE T ...

  4. AOP与IOC的概念(即spring的核心)

    a) IOC:Spring是开源框架,使用框架可以使我们减少工作量,提高工作效率并且它是分层结构,即相对应的层处理对应的业务逻辑,减少代码的耦合度.而spring的核心是IOC控制反转和AOP面向切面 ...

  5. 8-5接口测试用例设计与编写2 rest-assured

    rest-assured 简约的接口测试DSL 支持xml json的结构化解析 支持xpath jsonpath gpath等多种解析方式 对Spring的支持比较前面 底层是httpclient ...

  6. Delphi屏幕截图的实现

    首先要获得设备环境的句柄,可以通过GetDC函数来获得,对于这个函数,MSDN上是这样说明的 The GetDC function retrieves a handle to a device con ...

  7. duilib库分析4.第二篇UIBase

    DUiLib 源码分析 ——以UiLib 1.01版为分析目标 ——colin3dmax 分析于2011-6-16 19:44------------------------------------- ...

  8. JLOI 2013 卡牌游戏 bzoj3191

    题目描述 N个人坐成一圈玩游戏.一开始我们把所有玩家按顺时针从1到N编号.首先第一回合是玩家1作为庄家.每个回合庄家都会随机(即按相等的概率)从卡牌堆里选择一张卡片,假设卡片上的数字为X,则庄家首先把 ...

  9. fiddler设置抓取HTTPS协议数据包

    1.打开工具里的选项 2.选择弹窗中的HTTPS选项,如下图进行勾选 3.若浏览器显示不安全链接则需要添加证书 提示如下点击确定证书安装成功,可以查看安装的证书,点击Action 下图即可查看fidd ...

  10. react 16更新

    1.render新的返回类型 render方法支持两种新的返回类型:数组(由React元素组成)和字符串 2.错误处理 16之前,组件在运行期间如果执行出错,就会阻塞整个应用的渲染,这时候只能刷新页面 ...