您好,登录后才能下订单哦!
一、简介
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之间
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。