美文网首页图数据库Neo4j
Neo4j Cypher Query Language学习(三)

Neo4j Cypher Query Language学习(三)

作者: 布口袋_天晴了 | 来源:发表于2018-07-28 15:02 被阅读100次

    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教程

    相关文章

      网友评论

        本文标题:Neo4j Cypher Query Language学习(三)

        本文链接:https://www.haomeiwen.com/subject/mtdgmftx.html