Neo4j4-Neo4j基础操作(下)

一、merge 操作

  1. merge 子句简介

    (1) merge 子句的作用有2个,当模式(Pattern)存在时,匹配该模式;当模式不存在时,创建新模式。功能是 match 和 create 的组合

    (2) 在 merge 子句后,可以显式指定 on create 和 on match 子句,用于修改绑定的节点和关系的属性

    (3) 通过 merge 子句,可以指定图形中必须存在一个节点,该节点必须具有特定的标签、属性等。如果不存在,那么 merge 子句将创建相应的节点

 2. merge 子句的应用

    (1) 匹配搜索模式

# 匹配模式是一个节点有 person 标签,并且具有 name 属性
# 如果数据库存在该模式,那么匹配该模式,否则以这个模式创建一个新的节点
# 注: 1. 一个 merge 子句只能匹配一个模式
#     2. merge 匹配关系须指定关系类型

match (neo:Person {name: 'neo'})
return neo;

    (2) 在 merge 子句中指定 on create 子句

# 如果需要创建节点,那么执行 on create 子句,修改节点的属性
merge (keanu:Person {name: 'keanu'})
on create set keanu.created = timestamp()
return keanu;

    (3) 在 merge 子句中指定 on match 子句

# 如果节点已经存在于数据库中,那么执行 on match 子句,修改节点的属性
merge (person:Person)
on match set person.found=true,person.lastAccessed=timestamp()
return person;

    (4) 在 merge 子句中同时指定 on create 子句和 on match 子句

merge (keanu:Person {name: 'keanu'})
on create set keanu.created = timestamp()
on match set keanu.lastseen = timestamp()
return keanu;

    (5) merge 子句用于 match 或 create 一个关系

match (charlie:Person {name:'charlie'}),(wallstreet:Movie {title:'wall street'})
merge (charlie)-[r:acted_in]->(wallstreet)
return charlie,r,wallstreet;

    (6) merge 子句用于 match 和 create 多个关系

match (oliver:Person {name:'oliver'}),(reiner:Person {name: 'rob'})
merge (oliver)-[:directed]->(movie:Movie)<-[:acted_in]-(reiner)
return oliver,movie,reiner;

    (7) merge 子句用于子查询

match (person:Person)
merge (city:City {name:person.born_in})
return person;

match (person:Person)
merge (person)-[r:HAS_CHAUFFEUR]->(chauffeur:Chauffeur { name: person.chauffeurName })
return person.name, person.chauffeurName, chauffeur;

match (person:Person)
merge (city:City { name: person.bornIn })
merge (person)-[r:BORN_IN]->(city)
return person.name, person.bornIn, city;

二、运算符

  1. 算术运算符

    (1) +(加),-(减),*(乘),/(除)

    (2) %(取余),^(异或)

  2. 比较运算符

    (1) =(等于),<>(不等于)

    (2) <(小于),>(大于),<=(小于等于),>=(大于等于)

  3. 关系运算符

    (1) and(且),or(或),not(非)

    (2) xor(异或)

  4. 字符串运算符

      +(拼接)

return "abc" + "123";

  5. 列表运算符

    (1) +(拼接)

    (2) in

match (n:person) where n.hobby in ["唱", "跳", "rap", "篮球"]
return n;

  6. 正则表达式

      =~(正则表达式)

// like
match (n:person) where n.name =~'.*张.*' return n;

  7. 字符串匹配

    (1) starts with(以...开始)

    (2) ends with(以...结束)

    (3) contains(包含) 

三、Neo4j 关键字

  1. limit 和 skip

    (1) limit 用于最大查询多少条数据

match (n) return n limit 25;

    (2) skip 用于跳过多少条数据

match (n) return n skip 5;

  2. order by

      order by 子句,对 match 的结果排序,默认升序

      降序排序需要使用 desc 关键字

match (n) order by id(n) desc
return n;

match (n) order by n.name
return n;

  3. union

      union,用于将两个查询结果进行合并,注意查询结果的字段须一致

match (n:role) return n.name as name
union
match (m:person) return m.name as name

  4. distinct

      distinct关键字,用于查询语句,返回的是去重后的值

match (n:person) return distinct(n.name)

四、索引和约束

  1. index 索引

    (1) neo4j 支持节点和关系属性上的索引,以提高应用程序的性能

    (2) 可以为具有想用标签名称的所有节点的属性创建索引

    (3) 可以在 match、where 或 in 运算符上使用这些索引来加快查询操作

    (4) 创建索引:create index

    (5) 删除索引:drop index

//创建索引
create index on :person (name);

//删除索引
drop index on :person (name);

  2. unique 约束

      unique 约束可以避免重复记录,强制执行数据完整性规则

# 创建唯一约束
create constraint on (n:person) assert n.name is unique;
# 删除唯一约束
drop constraint on (n:person) assert n.name is unique;

  • 2
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

晴雪月乔

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值