Neo4j用CQL作为查询语言

CQL 

  • Neo4j图形数据库的查询语言
  • 是一种声明性模式匹配语言
  • 遵循SQL语法
  • 语法是非常简单且人性化、可读的格式

1.启动服务,打开浏览器

  在数据浏览器中的美元提示符下键入命令

2.常用命令

  (1)CREATE

    • 创建没有属性的节点
    • 使用属性创建节点
    • 在没有属性的节点之间创建关系
    • 使用属性创建节点之间的关系
    • 为节点或关系创建单个或多个标签

  创建节点

CREATE (<node-name>:<label-name>)

  eg:

    CREATE (emp:Employee)  

    创建一个标签和一个节点,在数据库中创建一个带有标签名“Employee”的节点“emp”

    创建带有属性的节点

CREATE (
<node-name>:<label-name>
{
<Property1-name>:<Property1-Value>
........
<Propertyn-name>:<Propertyn-Value>
}
)

  eg:

    CREATE (dept:Dept { deptno:10,dname:"Accounting",location:"Hyderabad" })

    创建:

      一个标签,即“Dept”;

      一个节点,即“dept”;

      三个属性,即deptno,dname,location

  创建关系

    • 单向关系
    • 双向关系
CREATE (<node1-name>:<label1-name>)-
[(<relationship-name>:<relationship-label-name>)]
->(<node2-name>:<label2-name>)

  eg:

  CREATE (p1:Profile1)-[r1:LIKES]->(p2:Profile2)

  From Node——节点名称 p1,节点标签名称profile1

  To Node——节点名称p2,节点标签名称Profile2

  r1是关系名称,LIKES是一个关系标签名称

  (2)MATCH和

    MATCH

    • 从数据库获取有关节点和属性的数据
    • 从数据库获取有关节点,关系和属性的数据
MATCH
(
<node-name>:<label-name>
)

   RETURN 

    • 检索节点的某些属性
    • 检索节点的所有属性
    • 检索节点和关联关系的某些属性
    • 检索节点和关联关系的所有属性
RETURN
<node-name>.<property1-name>,
........
<node-name>.<propertyn-name>

  不能单独使用MATCH或RETURN命令,结合起来从数据库检索数据

  MATCH + RETURN命令

    • 检索节点的某些属性
    • 检索节点的所有属性
    • 检索节点和关联关系的某些属性
    • 检索节点和关联关系的所有属性
MATCH Command
RETURN Command

  eg:

    MATCH (dept:Dept) return dept

    MATCH (dept: Dept) RETURN dept.deptno,dept.dname

  (3)WHERE

  过滤MATCH查询的结果

WHERE <condition> <boolean-operator> <condition>

  <boolean-operator>  AND,OR,NOT,XOR

  <condition>

<property-name> <comparison-operator> <value>

  <comparison-operator>  =,<>,<,>,<=,>=

  eg:

    CREATE (emp:Employee{id:1001,name:"Lokesh",sal:35000,deptno:10})

    CREATE (emp:Employee{id:1002,name:"abc",sal:28000,deptno:20})

    CREATE (emp:Employee{id:1003,name:"xyz",sal:35000,deptno:30})

    CREATE (emp:Employee{id:1004,name:"Mno",sal:32000,deptno:40})

    查询

    MATCH (emp:Employee) RETURN emp.id,emp.name,emp.salary,emp.deptno

  MATCH (emp:Employee) WHERE emp.name = 'abc' RETURN emp

  MATCH (emp:Employee) WHERE emp.name = 'abc' OR emp.name='xyz' RETURN emp.id,emp.name,emp.sal,emp.deptno

  使用WHERE创建关系

    • 创建两个现有节点之间的关系
    • 一次创建两个节点和它们之间的关系
    • 使用WHERE子句创建两个现有节点之间的关系
MATCH (<node1-label-name>:<node1-name>),(<node2-label-name>:<node2-name>)
WHERE <condition>
CREATE (<node1-label-name>)-[<relationship-label-name>:<relationship-name>
{<relationship-properties>}]->(<node2-label-name>)

  eg:

    CREATE (e:Customer{id:"1001",name:"Abc",dob:"01/10/1982"})

    CREATE (cc:CreditCard{id:"5001",number:"1234567890",cvv:"888",expiredate:"20/17"})

    MATCH (cust:Customer),(cc:CreditCard)  WHERE cust.id = "1001" AND cc.id= "5001"  CREATE (cust)-[r:DO_SHOPPING_WITH{shopdate:"12/12/2014",price:55000}]->(cc)  RETURN r

  (4)DELETE

    • 删除节点
    • 删除节点及相关节点和关系

  删除节点

DELETE <node-name-list>

  eg:

    CREATE (dept:Dept { deptno:10,dname:"Accounting",location:"Hyderabad" })

    MATCH (d: Dept) RETURN d

  MATCH (d: Dept) DELETE d

  删除节点和关系

DELETE <node1-name>,<node2-name>,<relationship-name>

  eg:

    CREATE (p1:Profile1)-[r1:LIKES]->(p2:Profile2)

    MATCH (p1:Profile1)-[r]-(p2:Profile2)RETURN p1,r,p2

  MATCH (p1:Profile1)-[r]-(p2:Profile2) DELETE p1,r,p2

  两个节点及其关联都被删除了

  MATCH (p1:Profile1)-[r]-(p2:Profile2) RETURN r

还有很多命令,以后再继续学习

Neo4j CQL基本使用的更多相关文章

  1. neo4j CQL 使用

    neo4j CQL 使用 1. create命令 CREATE (emp:Employee) #创建一个emp 员工标签 CREATE (dept:Dept) #部门标签 #Added 1 label ...

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

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

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

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

  4. NEO4j简单入门

    Neo4j是: 一个开源 无Schema 没有SQL 图形数据库 图形数据库也称为图形数据库管理系统或GDBMS. Neo4j的官方网站:http://www.neo4j.org Neo4j的优点 它 ...

  5. 一文教你用 Neo4j 快速构建明星关系图谱

    更多有趣项目及代码见于:DesertsX/gulius-projects 前言 本文将带你用 neo4j 快速实现一个明星关系图谱,因为拖延的缘故,正好赶上又一年的4月1日,于是将文中的几个例子顺势改 ...

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

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

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

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

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

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

  9. 初识Neo4j

    Neo4j是一个世界领先的开源图形数据库. 它是由Neo技术使用Java语言完全开发的. Neo4j的优点 它很容易表示连接的数据 检索/遍历/导航更多的连接数据是非常容易和快速的 它非常容易地表示半 ...

随机推荐

  1. Linux代理服务器使用

    1. 介绍 代理(即网络代理)是一种特殊的网络服务, 允许一个网络终端(客户端)通过这个服务与另一个终端(服务器)进行非直接连接,从而提供服务. 其中, 提供代理的网络终端称为代理服务器(Proxy ...

  2. Triton 学习

    介绍 Triton 是一款动态二进制分析框架,它支持符号执行和污点分析,同时提供了 pintools 的 python 接口,我们可以使用 python 来使用 pintools 的功能. Trito ...

  3. CodeForces - 24D :Broken robot (DP+三对角矩阵高斯消元 随机)

    pro:给定N*M的矩阵,以及初始玩家位置. 规定玩家每次会等概率的向左走,向右走,向下走,原地不动,问走到最后一行的期望.保留4位小数. sol:可以列出方程,高斯消元即可,发现是三角矩阵,O(N* ...

  4. IntToBinaryString

    void IntToBinaryString(int devisor,char* pBinStr) { int i; int remainder; ;i<;i++) { remainder=de ...

  5. junit4的进一步探讨

    上次只是大概记录了下junit4几个常见标签的用法. 在这篇文章中,我们来进一步分析junit4的用法. 1.断言 junit4中一个很常见的用法就是断言.说到断言,大家再熟悉不过了.不过也许有的朋友 ...

  6. LeetCode 1048. Longest String Chain

    原题链接在这里:https://leetcode.com/problems/longest-string-chain/ 题目: Given a list of words, each word con ...

  7. redis windows版本的使用

    ServiceStack的redis-windows下载 下载新的版本解压到硬盘,使用黑窗口切换到路径后执行 redis-server redis.windows.conf 即可看到redis启动到6 ...

  8. Ubuntu下设置 nginx php-fpm 自动启动 rc.local

    编辑 root@ubuntu:/usr/sbin# vim /etc/init.d/rc.local /usr/sbin/php-fpm /usr/sbin/nginx 保存!

  9. BZOJ1034 ZJOJ2008 泡泡堂BNB

    BZOJ1034 ZJOJ2008 泡泡堂BNB Description 第XXXX届NOI期间,为了加强各省选手之间的交流,组委会决定组织一场省际电子竞技大赛,每一个省的代表 队由n名选手组成,比赛 ...

  10. uni-app 模拟器

    1.安装MuMu模拟器 Android模拟器端口: 7555 2.安装夜神模拟器 Android模拟器端口: 62001