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 - 字符串函数:

UPPER语法

语法: UPPER (<input-string>)

LOWER语法

语法: LOWER (<input-string>)

SUBSTRING语法

语法: SUBSTRING (<input-string>,<startIndex>,<endIndex>)


查看
UPPER(p.name)  把name属性值大写
LOWER(p.name)  把name属性值小写

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

SUBSTRING(p.name,起始位置,结束位置)


2.Neo4j CQL - AGGREATION聚合:

COUNT语法

语法: COUNT (<value>)

语法: COUNT(*)

MAX语法;MIN语法

语法: MAX (<property-name>)

语法: MIN (<property-name>)

SUM语法;AVG语法

语法: SUM (<property-name>)

语法: AVG (<property-name>)


不加限制条件的,统计
添加限制条件的,统计
最小、最大、平均、求和


3.Neo4j CQL - 关系函数:

STARTNODE函数语法/ENDNODE函数语法

语法: STARTNODE(<relationship-label-name>)  

语法: ENDNODE(<relationship-label-name>)  


先创建节点以及节点之间的关系
MATCH(p)-[r:LIKES]->(m) RETURN STARTNODE(r)   查到了喜欢关系的头节点有哪些
MATCH(p)-[r:LIKES]->(m) RETURN ENDNODE(r)   查到了喜欢关系的尾节点有哪些
查看关系的ID、TYPE
查看尾节点的ID


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

数据备份:

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

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

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

数据库

数据库恢复:

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


5.Neo4j CQL - 索引:

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

·Create Index 创建索引

·Drop Index 丢弃索引

语法: CREATE INDEX ON:<label-name> (<property-name>)

语法: DROP INDEX ON:<label-name> (<property-name>)


按Person类的名字字段,创建一个索引
删除 按Person类的名字字段创建的索引


6.Neo4j CQL - UNIQUE约束:

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

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

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

UNIQUE约束

创建唯一约束语法:

CREATE CONSTRAINT ON (<label-name>) ASSERT <property-name> IS UNIOUE


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

有重复节点的知识库
判断name属性为唯一值,但是节点中有两个name="姚明"

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

创建限制成功
加入第一个id=12的节点
加入第二个id=12的节点,出现报错


解除限制:

移除限制
再往数据库里添加id=12的节点成功
能从数据库中查看到两个id=12的节点


参考文章:

【1】W3Cschool Neo4j教程

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 关于Mongodb的全面总结 MongoDB的内部构造《MongoDB The Definitive Guide》...
    中v中阅读 32,125评论 2 89
  • ORA-00001: 违反唯一约束条件 (.) 错误说明:当在唯一索引所对应的列上键入重复值时,会触发此异常。 O...
    我想起个好名字阅读 10,794评论 0 9
  • 观其大纲 page 01 基础知识 1 MySQL数据库概要 2 简单MySQL环境 3 数据的存储和获取 4 M...
    周少言阅读 8,325评论 0 33
  • 幽幽怨怨 ,细细绵绵,如丝如线,如梦如幻。 一说到雨,总是南方的代名词,朔方的雨是不成雨的。他们的冬天太冷,水滴...
    独白sf阅读 1,833评论 0 2
  • 第一:测试用例格式包括十大特点 用例编号 测试项 测试标题 用例属性 重要级别:高中低 预置条件 测试输入 操作步...
    晓可加油阅读 9,273评论 0 1