Neo4j Cypher Query Language学习(三)

Neo4j是: ·一个开源 ·无Schema ·没有SQL ·图形数据库

该篇文章主要内容包括Neo4j CQL函数、Neo4j Admin管理员:

1.Neo4j CQL - 字符串函数

2.Neo4j CQL - AGGREATION聚合

3.Neo4j CQL - 关系函数

4.Neo4j - 数据库备份和恢复

5.Neo4j CQL - 索引

6.Neo4j CQL - UNIQUE约束




1.Neo4j CQL - 字符串函数:

Neo4j Cypher Query Language学习(三)_第1张图片

UPPER语法

语法: UPPER ()

LOWER语法

语法: LOWER ()

SUBSTRING语法

语法: SUBSTRING (,,)


Neo4j Cypher Query Language学习(三)_第2张图片
查看
Neo4j Cypher Query Language学习(三)_第3张图片
UPPER(p.name)  把name属性值大写
Neo4j Cypher Query Language学习(三)_第4张图片
LOWER(p.name)  把name属性值小写

查找所有人中,姓名中以"布口袋"开始命名的节点们。

Neo4j Cypher Query Language学习(三)_第5张图片
SUBSTRING(p.name,起始位置,结束位置)


2.Neo4j CQL - AGGREATION聚合:

Neo4j Cypher Query Language学习(三)_第6张图片

COUNT语法

语法: COUNT ()

语法: COUNT(*)

MAX语法;MIN语法

语法: MAX ()

语法: MIN ()

SUM语法;AVG语法

语法: SUM ()

语法: AVG ()


Neo4j Cypher Query Language学习(三)_第7张图片
不加限制条件的,统计
Neo4j Cypher Query Language学习(三)_第8张图片
添加限制条件的,统计
Neo4j Cypher Query Language学习(三)_第9张图片
最小、最大、平均、求和


3.Neo4j CQL - 关系函数:

Neo4j Cypher Query Language学习(三)_第10张图片

STARTNODE函数语法/ENDNODE函数语法

语法: STARTNODE()  

语法: ENDNODE()  


Neo4j Cypher Query Language学习(三)_第11张图片
先创建节点以及节点之间的关系
Neo4j Cypher Query Language学习(三)_第12张图片
MATCH(p)-[r:LIKES]->(m) RETURN STARTNODE(r)   查到了喜欢关系的头节点有哪些
Neo4j Cypher Query Language学习(三)_第13张图片
MATCH(p)-[r:LIKES]->(m) RETURN ENDNODE(r)   查到了喜欢关系的尾节点有哪些
Neo4j Cypher Query Language学习(三)_第14张图片
查看关系的ID、TYPE
Neo4j Cypher Query Language学习(三)_第15张图片
查看尾节点的ID


4.Neo4j - 数据库备份和恢复:

数据备份:

1)首先找到数据存放的位置   

2)备份时,关掉Neo4j的数据库服务器

找到Neo4j的bin目录,同级有一个data目录。  完整备份的话,可以直接备份data整个文件。

Neo4j Cypher Query Language学习(三)_第16张图片
数据库

数据库恢复:

恢复data文件夹及其内容就可以了


5.Neo4j CQL - 索引:

为具有相同标签的节点创建索引

·Create Index 创建索引

·Drop Index 丢弃索引

语法: CREATE INDEX ON: ()

语法: DROP INDEX ON: ()


Neo4j Cypher Query Language学习(三)_第17张图片
按Person类的名字字段,创建一个索引
Neo4j Cypher Query Language学习(三)_第18张图片
删除 按Person类的名字字段创建的索引


6.Neo4j CQL - UNIQUE约束:

在Neo4j数据库中,CQL CREATE命令始终创建新的节点或关系,这意味着即使您使用相同的值,它也会插入一个新行。 根据我们对某些节点或关系的应用需求,我们必须避免这种重复。 然后我们不能直接得到这个。 我们应该使用一些数据库约束来创建节点或关系的一个或多个属性的规则。

·避免重复记录、避免创建重复节点

·强制执行数据完整性规则

UNIQUE约束

创建唯一约束语法:

CREATE CONSTRAINT ON () ASSERT IS UNIOUE


在数据库中,已经存在重复节点的情况下:

Neo4j Cypher Query Language学习(三)_第19张图片
有重复节点的知识库
Neo4j Cypher Query Language学习(三)_第20张图片
判断name属性为唯一值,但是节点中有两个name="姚明"

这个语句CREATE CONSTRAINT ON (p:Person) ASSERT p.id IS UNIQUE   对id进行约束比较恰当些,每个人有一个唯一ID。  当重复时,就会报错。

Neo4j Cypher Query Language学习(三)_第21张图片
创建限制成功
Neo4j Cypher Query Language学习(三)_第22张图片
加入第一个id=12的节点
Neo4j Cypher Query Language学习(三)_第23张图片
加入第二个id=12的节点,出现报错


解除限制:

Neo4j Cypher Query Language学习(三)_第24张图片
移除限制
Neo4j Cypher Query Language学习(三)_第25张图片
再往数据库里添加id=12的节点成功
Neo4j Cypher Query Language学习(三)_第26张图片
能从数据库中查看到两个id=12的节点


参考文章:

【1】W3Cschool Neo4j教程

你可能感兴趣的:(Neo4j Cypher Query Language学习(三))