Neo4j-1.3 关系

  • Neo4j图数据库用图模型来存储和管理数据
  • 关系是定向的(有方向)
  • 依据方向性,Neo4j关系分为两类:
    • 单向关系
    • 双线关系
  • 用CREATE命令创建两个节点之间的关系:
    • 在两个现有节点之间创建无属性的关系
    • 在两个现有节点之间创建有属性的关系
    • 在两个新节点之间创建无属性的关系
    • 在两个新节点之间创建有属性的关系
    • 在具有WHERE子句的两个退出节点之间创建/不使用属性的关系
  • 每个关系包含两个节点:
    • 从节点(From Node)
    • 到节点 (To Node)
  • 对于节点,有两种关系:
    • 外向关系
    • 传入关系

在两个现有节点之间创建无属性的关系

用如下命令检索现有的两个节点,并创建它们之间的关系:

MATCH (<node1-label-name>:<node1-name>), (<node2-label-name>:<node2-name>)
CREATE
  (<node1-label-name>)-[<relationship-label-name>:<relationship-name>]->(<node2-label-name>)
RETURN <relationship-label-name>

语法说明:

S.No.

语法元素

描述

1.

MATCH,CREATE,RETURN

Neo4J CQL关键字。

2.

<node1-name>

它用于创建关系的“From Node”的名称。

3.

<node1-label-name>

它用于创建关系的“From Node”的标签名称。

4.

<node2-name>

它用于创建关系的“To Node”的名称。

5.

<node2-label-name>

它用于创建关系的“To Node”的标签名称。

6.

<relationship-name>

这是一个关系的名称。

7.

<relationship-label-name>

它是一个关系的标签名称。

RETURN子句是可选的,使用后可立即看到结果。

在两个现有节点之间创建有属性的关系

用如下命令在现有的两个节点之间创建有属性的关系:

MATCH (<node1-label-name>:<nade1-name>),(<node2-label-name>:<node2-name>)
CREATE
  (<node1-label-name>)-[<relationship-label-name>:<relationship-name>{<define-properties-list}]

语法说明:

S.No.

语法元素

描述

1.

MATCH,CREATE,RETURN

他们是Neo4J CQL关键词。

2.

<node1-name>

它是用于创建关系的“From Node”的名称。

3.

<node1-label-name>

它是用于创建关系的“From Node”的标签名称。

4.

<node2-name>

它是用于创建关系的“To Node”的名称。

5.

<node2-label-name>

它是用于创建关系的“To Node”的标签名称。

6.

<relationship-name>

这是一个关系的名称。

7.

<relationship-label-name>

它是一个关系的标签名称。

8.

<define-properties-list>

它是分配给新创建关系的属性(名称 - 值对)的列表。

RETURN子句是可选的,使用后可立即看到结果。

<define-properties-list>的语法是:

{ 
   <property1-name>:<property1-value>,
   <property2-name>:<property2-value>,
   ...
   <propertyn-name>:<propertyn-value>
}

注意:

  • 使用Colon(:)运算符后来分割属性名称和值
  • 使用Comma(,)运算符将Property于另一对Property分开

创建没有属性的节点和关系

以下语句创建数据库中不存在的节点和他们之间的新关系:

CREATE  
   (<node1-label-name>:<node1-name>)-
   [<relationship-label-name>:<relationship-name>]->
   (<node1-label-name>:<node1-name>)
RETURN <relationship-label-name>

语法说明:

S.No.

语法元素

描述

1.

CREATE,RETURN

他们是Neo4J CQL关键字。

2.

<node1-name>

它用于创建关系的“From Node”的名称。

3.

<node1-label-name>

它用于创建关系的“From Node”的标签名称。

4.

<node2-name>

它用于创建关系的“To Node”的名称。

5.

<node2-label-name>

它用于创建关系的“To Node”的标签名称。

6.

<relationship-name>

这是一个关系的名称。

7.

<relationship-label-name>

它是一个关系的标签名称。

RETURN子句是可选的,使用后可立即看到结果。

创建新节点和有属性的关系

以下语句创建数据库中没有的节点和他们之间有属性的新关系:

CREATE  
    (<node1-label-name>:<node1-name>{<define-properties-list>})-
    [<relationship-label-name>:<relationship-name>{<define-properties-list>}]
    ->(<node1-label-name>:<node1-name>{<define-properties-list>})
RETURN <relationship-label-name>

S.No.

语法元素

描述

1.

CREATE,RETURN

他们是Neo4J CQL关键字。

2.

<node1-name>

它用于创建关系的“From Node”的名称。

3.

<node1-label-name>

它用于创建关系的“From Node”的标签名称。

4.

<node2-name>

它用于创建关系的“To Node”的名称。

5.

<node2-label-name>

它用于创建关系的“To Node”的标签名称。

6.

<relationship-name>

这是一个关系的名称。

7.

<relationship-label-name>

它是一个关系的标签名称。

RETURN子句是可选的,使用后可立即看到结果。 {<define-property-list>}的内容格式如下:

{ 
    <property1-name>:<property1-value>,
    <property2-name>:<property2-value>,
    ...
    <propertyn-name>:<propertyn-value>
}

检索关系节点的详细信息

使用MATCH+RETURN来查看单独创建或者作为关系的一部分创建的节点的详细信息。

MATCH 
(<node1-label-name>)-[<relationship-label-name>:<relationship-name>]->(<node2-label-name>)
RETURN <relationship-label-name>

S.No.

语法元素

描述

1.

MATCH,RETURN

他们是Neo4j CQL关键字。

2.

<node1-label-name>

它是用于创建关系的“From Node”的标签名称。

3.

<node2-label-name>

它是用于创建关系的“To Node”的标签名称。

4.

<relationship-name>

它是一个关系的名称。

5.

<relationship-label-name>

它是关系的标签名称。

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • Neo4j-3.2 UNION约束DROP UNION

    悠扬前奏
  • Groovy-14.JMX

    悠扬前奏
  • Neo4j-1.6 DELETE删除和REMOVE删除

    悠扬前奏
  • Struts2之Validation的简单使用实例

    本来不打算写这些细枝末节的东西了,因为在文档中都有现成的实例,写了也只能自己用来参考,不过这个Validation文档中给的不全,从网上查之后才知道用法。 首先...

    the5fire
  • shell学习一变量的定义 原

    用符号$加上变量名如 $name 或${name},{}括号是为了确定变理边界,推荐使用

    用户2603479
  • python 字典i

    字典     字典类似于你通过联系人名称查找地址和联系人详细情况的地址簿,即,我们把键(名字)和值(详细情况)联系在一起。注意,键必须是唯一的,就像如果有两个...

    py3study
  • mange

    py3study
  • 海量数据迁移之分区并行抽取(r2笔记53天)

    在之前的章节中分享过一些数据迁移中并行抽取的细节,比如一个表T 很大,有500G的数据,如果开启并行抽取,默认数据库中并行的最大值为64,那么生成的dump文件...

    jeanron100
  • 【Python基础】函数的返回

    很多时候,函数并非直接输出,相反,它可以处理一些数据,并返回一个值或者一组值,称之为返回值。

    DataScience
  • Python操作Redis,你要的都在这了!

    崔庆才

扫码关注云+社区

领取腾讯云代金券