一、简介


    Cypher语言是在学习Neo4j时用到数据库操作语言(DML),涵盖对图数据的增删改查,跟SQL有较大不同,本文仅记录一些要点备查


二、详述


    1、基本概念

        Neo4j中不存在表的概念,只有两类:节点(Node)和关联(Relation),可以简单理解为图里面的点和边,在数据查询中,节点一般用小括号(),关联用中括号[]。当然也隐含路径的概念,是用节点和关联表示的,如:(a)-[r]->(b),表示一条从节点a经关联r到节点b的路径

    2、创建语句

        1)创建节点

            create (a) 创建空节点

            create (a:Person) 创建标签(可以理解为类)为Person的节点

            create (a:Person {name:'Kaine',age:28}) 创建标签为Person,属性name值为Kaine,属性age值为28的节点

        2)创建关联

            match (a),(b)

            where a.name='Kaine' and b.name='Sharon'

            create (a)-[r]->(b)

            创建a节点和b节点的路径,此时变量r即代表关联,它也可以有标签

    2、查询关键字

        match:用来匹配一定模式,可以是简单的节点、关联,也可以是复杂的路径

        where:用来限定条件,一般是限定match中的出现变量的属性

        return:返回结果

        start:开始节点,一般用于有索引的节点或者关联

    3、基本查询样式

        match ... where ... return ...

        如果match有多个对象,用逗号隔开;

        如果where有多个条件,用and连接;

        如果return有多个变量,用逗号隔开

    4、查询举例

        match (n) return n 查询所有节点及关联

        match (a)-[r]->(b) where a.name='Kaine' return a,b 查询属性name的值是Kaine的节点,及其所有关联节点

        match (a)-[*1..3]->(b) where a.name='Kaine' return a,b 查询属性name值是Kaine的节点,及其所有距离为1到3的关联节点,

        match (a)-[*2]->(b) where a.name='Kaine' and not (a)-[*1]->(b) return a,b 查询属性name的值是Kaine的节点,及其所有距离为2并且去除距离为1的节点。(在计算好友的好友时会用到,即如果a、b、c三个人都认识,如果仅计算跟a距离为2的人的时候会把b、c也算上,因为a->b->c,或者a->c->b都是通路)

        注:关联的中括号内数字的含义

            n 距离为n

            ..n 最大距离为n

            n.. 最小距离为n

            m..n 距离在m到n之间