创建节点、关系

创建节点(小明):create (n:people{name:’小明’,age:’18’,sex:’男’}) return n; 
创建节点(小红): create (n:people{name:’小红’,age:’18’,sex:’女’}) return n; 
创建关系(小明送礼物给小红):小明节点id为0,小红节点id为1 
start a =node(0),b=node(1) create (a)-[n:gift]->(b)return n

属性查询

查询18岁的人 
Match (n: people) where n.age = 18 return n

查询大于18岁的人 
Match (n: people) where n.age > 18 return n

查询大于等于18岁的人 
Match (n: people) where n.age >= 18 return n

查询不等于18岁的人 
Match (n: people) where n.age <> 18 return n

关系查询

正向查询 
查询小明送礼物给了哪些人,有两种写法:(以下例子类似) 
Match (n:people)-[: gift]->(end:people) where n.name=’小明’ return end 
Match (n:people{name: ‘小明’})-[:gift]->(end:people) return end

反向查询 
查询哪些人送了礼物给小明 
Match (n:people{name: ‘小明’})<-[:gift]-(end:people) return end

无方向查询 
查询和小明有礼物来往的人 
Match (n:people{name: ‘小明’})-[:gift]-(end:people) return end

ID查询

在neo4j中,每一个节点,会自动有一个唯一Id。 
查找id为1的节点,有两种方式:

Start n = node(1) return n ---新版本已修改为下面方式
Match (n) where ID(n)=1 return n

级次查询(树形遍历)

这里写图片描述 
 
以根部为条件,查询第二层的节点

Match (start:people{name:’小明’})-[:gift*2..2]->(end:people) return end

以根部为条件,查询第一层和第二层的节点

Match (start:people{name:’小明’})-[:gift*1..2]->(end:people) return end

以根部为条件,按级次查询出所有直接或间接获得过小明的礼物的人

Match (start:people{name:’小明’})-[:gift*]->(end:people) return end

Delete

删除2个节点之间的关系:

Match (x:people{name:’小明’})-[r:gift]->(y:people{name:’小红’}) delete r

删除节点,会删除和该节点有关的所有关系:

Match (n:people{name:’小红’}) delete n

Count

(不按属性)查询标签(people)中一共有多少节点(人):

Match (n:people) return count(n)

(按属性)查询标签(people)中年龄为18岁的一共有多少节点(人): 
三种写法:

Match (n:people) where n.age=18 return count(n) 
Match (n:people{age:’18’}) return count(n) 
Match (n:people) return count(n.age=18)

Limit

查询标签(people)中的10个节点(人):

Match (n:people) return n limit 10

Distinct

查询标签(people)中所有的不同的age:

Match (n:people) return distinct(n.age)

Order by

根据标签(people)中的name 排序:

Match(n:people) return n order by name (默认升序) 
Match(n:people) return n order by name asc (升序) 
Match(n:people) return n order by name desc (降序)

Union all (Union)

求并集,不去重(去重用Union):

Match(n:people) where n.age=18 return n.name as name 
Union all 
Match(n:friend) where n.age=18 return n.name as name

In

查询id为0,5,8的节点:

Match (n) where ID(n) IN[0,5,8] return n

Exists

判断节点是否存在 name这个属性:

Match (n) where exists(n.name) return n

With

查询name以‘小’开头的节点:

Match (n) where n.name starts with ‘小’ return n

查询name以‘明’结尾的节点:

Match (n) where n.name ends with ‘明’ return n

Contains

查询name中含有 ‘小’的节点

Match (n) where n.name Contains ‘小’ return n

neo4j 一些常用的CQL的更多相关文章

  1. Neo4j数据库学习一:安装和数据类型常用命令简介

    Neo4j数据库是图数据库 在数据库中,只有节点Nodes和关系Relationships Nodes用圆圈表示,Relationships用有向箭头表示 关系和节点都有属性(键值对) 安装3.3.7 ...

  2. 史上最全面的Neo4j使用指南

    Neo4j图形数据库教程 Neo4j图形数据库教程 第一章:介绍 Neo4j是什么 Neo4j的特点 Neo4j的优点 第二章:安装 1.环境 2.下载 3.开启远程访问 4.测试 第三章:CQL 1 ...

  3. 史上超全面的Neo4j使用指南

    Create by yster@foxmail.com 2018-7-10 我的博客:https://blog.csdn.net/yueshutong123 W3Cschool文档:https://w ...

  4. Neo4j图数据库从入门到精通

    目录 第一章:介绍 Neo4j是什么 Neo4j的特点 Neo4j的优点 第二章:安装 1.环境 2.下载 3.开启远程访问 4.启动 第三章:CQL 1.CQL简介 2.Neo4j CQL命令/条款 ...

  5. Neo4j图数据库从入门到精通(转)

    add by zhj: 转载时,目录没整理好,还会跳转到原文 其实RDB也可以存储多对多的关系,使用的是中间表,GDB使用的是边,RDB中的实体存储在数据表,而GDB存储在节点.两者使用的底层技术不同 ...

  6. Neo4j Cypher语法(一)

    目录 Cypher手册详解 1 背景 2 唯一性 3 语法 3.1 命名规则 3.2 表达式 3.3 变量与保留关键字 3.4 参数 3.5 操作符 3.6 模式 3.7 列表 Cypher手册详解 ...

  7. 【图数据库】史上超全面的Neo4j使用指南

    转自:https://cloud.tencent.com/developer/article/1336299 在这篇文章中: 第一章:介绍 Neo4j是什么 Neo4j的特点 Neo4j的优点 第二章 ...

  8. Neo4j入门之中国电影票房排行浅析

    什么是Neo4j?   Neo4j是一个高性能的NoSQL图形数据库(Graph Database),它将结构化数据存储在网络上而不是表中.它是一个嵌入式的.基于磁盘的.具备完全的事务特性的Java持 ...

  9. 关于neo4j初入门(4)

    关于admin管理员 数据库备份和恢复 Neo4j数据库备份 步骤1 -点击“Neo4j Community”,如下图所示 Windows“开始”按钮>> "All Progra ...

随机推荐

  1. StorageClass-动态PVC

    StorageClass 之前我们部署了PV 和 PVC 的使用方法,但是前面的 PV 都是静态的,什么意思?就是我要使用的一个 PVC 的话就必须手动去创建一个 PV,我们也说过这种方式在很大程度上 ...

  2. Centos 7.3 搭建php7,mysql5.7,nginx1.10.1,redis

    一.安装nginx 更新系统软件(非必要) # yum update 安装nginx 1.下载nginx # wget http://nginx.org/download/nginx-1.15.2.t ...

  3. Go的包管理工具(一)

    在前面转载了系列文章:Golang 需要避免踩的 50 个坑,总得来说阅读量都挺大.今天这篇文章,咱们一起聊聊Go的依赖包管理工具. 背景 每一门语言都有其依赖的生态,当我们使用Java语言的时候,使 ...

  4. 怎样理解AJAX

    AJAX: Asynchronous JavaScript and XML, 翻译过来就是: 异步的JavaScript与XML 这已经成为了一个通用名词, 字面意义已经消失了, 因为现在使用Java ...

  5. django websocket 实现后台日志在web端展示(+前端vue设置)

    核心代码: @accept_websocket def get_log(req): if req.is_websocket(): print('收到websocket请求') with open(se ...

  6. 使用 FTP 迁移 SQL Server 数据_迁移数据_快速入门(SQL Server)_云数据库 RDS 版-阿里云

    背景信息 阿里云数据库 SQL Server 版导入数据有如下限制: 仅支持导入 SQL Server 2005.SQL Server 2008.SQL Server 2008R2 版本数据 仅支持全 ...

  7. StoneTab标签页CAD插件 3.2.0

    //////////////////////////////////////////////////////////////////////////////////////////////////// ...

  8. javascript数字格式化通用类——accounting.js使用

    简介 accounting.js 是一个非常小的JavaScript方法库用于对数字,金额和货币进行格式化.并提供可选的Excel风格列渲染.它没有依赖任何JS框架.货币符号等可以按需求进行定制. 代 ...

  9. django管理系统代码优化-分组(二)

    django管理系统代码优化-分组(二) 后续进行代码更新,优化 一优化的内容 优化前代码:https://www.cnblogs.com/pythonywy/p/11345626.html 路由进行 ...

  10. Django rest-framework框架-请求数据校验

    验证实例: class UserInfoSerializer(serializers.Serializer): title = serializer.CharField(error_messages= ...