0%

Neo4j的安装与使用

一、Neo4j的概述

  • Neo4j是一个高性能的,NOSQL图形数据库,它将结构化数据存储在网络上而不是表中。
  • 它是一个嵌入式的、基于磁盘的、具备完全的事务特性的Java持久化引擎,但是它将结构化数据存储在网络(从数学角度叫做图)上而不是表中。
  • Neo4j也可以被看作是一个高性能的图引擎,该引擎具有成熟数据库的所有特性。
  • 程序员工作在一个面向对象的、灵活的网络结构下而不是严格、静态的表中——但是他们可以享受到具备完全的事务特性、企业级的数据库的所有好处。

来自:百度百科

1、Neo4J的特点

  • Cypher是Neo4j的图形查询语言
  • 它遵循属性图数据模型
  • 它通过使用Apache Lucence支持索引
  • 它支持UNIQUE约束
  • 它支持完整的ACID(原子性,一致性,隔离性和持久性)规则
  • 它采用原生图形库与本地GPE(图形处理引擎)
  • 它支持查询的数据导出到JSON和XLS格式
  • 它提供了REST API,可以被任何编程语言(如Java,Spring,Scala等)访问
  • 它提供了可以通过任何UI MVC框架(如Node JS)访问的Java脚本
  • 它支持两种Java API:Cypher API和Native Java API来开发Java应用程序

2、Neo4j图数据库主要有以下构建块

  • 节点
    • 节点是图表的基本单位。 它包含具有键值对的属性
  • 属性
    • 属性是用于描述图节点和关系的键值对
  • 关系
    • 关系是图形数据库的另一个主要构建块。 它连接两个节点
    • 每个关系包含一个起始节点和一个结束节点
  • 标签
    • Label将一个公共名称与一组节点或关系相关联。
    • 节点或关系可以包含一个或多个标签
    • 我们可以为现有节点或关系创建新标签,也可删除标签
  • 数据浏览器

二、Neo4j的安装与使用

  • Neo4j有三种版本:社区版(免费)、桌面版(免费一年)、企业版(收费)
  • 社区版是 Neo4j 的全功能版本,适用于单实例部署,它完全支持Neo4j的关键功能,例如符合ACID标准的事务,密码和编程API。
  • 桌面版是开发人员使用本地 Neo4j 数据库的便捷方式,不适合生产环境。
  • 企业版扩展了社区版的功能,以包括性能和可伸缩性的关键功能,例如群集体系结构和在线备份功能。其他安全功能包括基于角色的访问控制和 LDAP 支持,例如,活动目录。它是具有规模和可用性要求的生产系统的选择,例如商业解决方案和关键内部解决方案。

地址相关:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
# 安装服务
neo4j install-service

# 卸载服务
neo4j uninstall-service

# 启动
neo4j start

# 停止
neo4j stop

# 重启
neo4j restart

# 查询服务状态
neo4j status

三、Cypher 简介

1、Cypher 语法

  • 常用的语法有
语法 描述
CREATE 创建节点,关系和属性
MATCH 检索有关节点,关系和属性数据,要匹配的图形模式。这是从图形中获取数据的最常见方法。
RETURN 返回查询结果
WHERE 提供条件过滤检索数据
DELETE 删除节点和关系
REMOVE 删除节点和关系的属性
ORDER BY 排序检索数据
SET 添加或更新标签属性
MERGE 创建节点,关系和属性
①、CREATE
  • 创建语法格式大致如下:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
// 方式一: 格式
CREATE (
<node-name>:<label-name>
{
<Property1-name>:<Property1-Value>
........
<Propertyn-name>:<Propertyn-Value>
}
)

// 方式二: 创建几点的时候,直接建立关系
CREATE (节点名称)-[:关系]->(节点名称)-[:关系]->(节点)


// 方式三 一个节点创建多个标签,Movie, Person是m节点的多个标签名称
CREATE (m:Movie:Person)
  • 来一个实战语法:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
// 创建大话西游两部电影节点 Movie
CREATE (moon:Movie {title:'大话西游之月光宝盒', released:1994, tagline:'是由周星驰彩星电影公司和西安电影制片厂联合摄制的爱情悲喜剧系列电影,由刘镇伟执导,周星驰、朱茵、吴孟达、蓝洁瑛、莫文蔚等主演'})
CREATE (marry:Movie {title:'大话西游之大圣娶亲', released:1995, tagline:'是由周星驰彩星电影公司和西安电影制片厂联合摄制的爱情悲喜剧系列电影,由刘镇伟执导,周星驰、朱茵、吴孟达、蓝洁瑛、莫文蔚等主演'})

// 创建人物节点 Person
CREATE (zhouxx:Person {name:'周星驰', born:1962})
CREATE (zy:Person {name:'朱茵', born:1962})
CREATE (wmd:Person {name:'吴孟达', born:1963})
CREATE (mww:Person {name:'莫文蔚', born:1964})
CREATE (ljy:Person {name:'蓝洁瑛', born:1965})
CREATE (luo:Person {name:'罗家英', born:1965})
CREATE (zsf:Person {name:'蔡少芬', born:1965})

// 创建人物与电影的关系
CREATE
(zhouxx)-[:ACTED_IN {roles:['至尊宝','孙悟空']}]->(moon),
(zhouxx)-[:ACTED_IN {roles:['至尊宝、孙悟空、夕阳武士']}]->(marry),
(zy)-[:ACTED_IN {roles:['紫霞仙子']}]->(moon),
(wmd)-[:ACTED_IN {roles:['二当家、猪八戒']}]->(moon),
(mww)-[:ACTED_IN {roles:['白晶晶']}]->(moon),
(ljy)-[:ACTED_IN {roles:[' 春三十娘']}]->(moon),
(luo)-[:ACTED_IN {roles:['唐三藏']}]->(moon),
(zsf)-[:ACTED_IN {roles:['铁扇公主']}]->(moon),
(zy)-[:ACTED_IN {roles:['紫霞仙子、青霞仙子、盘丝大仙']}]->(marry),
(wmd)-[:ACTED_IN {roles:['二当家、猪八戒']}]->(marry),
(mww)-[:ACTED_IN {roles:['白晶晶']}]->(marry),
(luo)-[:ACTED_IN {roles:['唐僧']}]->(marry),
(zsf)-[:ACTED_IN {roles:['铁扇公主']}]->(marry),
(ljy)-[:ACTED_IN {roles:[' 春三十娘']}]->(marry),
(zhouxx)-[:DIRECTED]->(moon),
(zhouxx)-[:DIRECTED]->(marry)

ACTED_IN 代表关系类型,表演的意思,DIRECTED 也是关系类型,导演

  • 执行上面命令之后,可得节点如下:

②、MATCH
  • MATCH 检索有关节点,关系和属性数据
  • 如下:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
// 查询所有节点
MATCH (n) RETURN n

// LIMIT 分页获取节点
MATCH (n) RETURN n LIMIT 10

// SKIP 跳过几个节点,LIMIT 分页
MATCH (n) RETURN n SKIP 10 LIMIT 2

// 查询导演的节点关系,加 LIMIT 25分页
MATCH p=()-[r:DIRECTED]->() RETURN p

// 查询 表演关系节点,分页
MATCH p=()-[r:ACTED_IN]->() RETURN p LIMIT 25
③、RETURN
  • RETURN常与其他语法组合使用
  • 可以返回节点的某些属性,或所有属性,关联关系的属性等
1
2
3
4
5
6
7
8
9
10
11
12

// 查询name=周星驰的节点
MATCH (n:Person{name:"周星驰"}) return n;

// 返回节点的部分属性
MATCH (n:Person{name:"周星驰"}) return n.name,n.born;

// 查询 Person类型的所有节点
MATCH (n:Person) return n;

// 查询 Persion和Movie两种类型的节点
MATCH (n:Person) MATCH(a:Movie) return n,a;
④、WHERE
  • WHERE子句一般是用来过滤MATCH查询的结果
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19

// 查询 Person节点,born=1962的所有节点
MATCH (n:Person) WHERE n.born=1962 return n;

// in 查询
MATCH (p:Person) WHERE p.name in["周星驰","朱茵"] return p;

// 查询 born 不为空的
MATCH (p:Person) WHERE p.born is NOT NULL return p;

// 查询 born 为空的
MATCH (p:Person) WHERE p.born is NULL return p;

// OR 关系运算符,还有AND
MATCH (n:Person) WHERE n.name="周星驰" OR n.born=1962 return n;

//这种类似 MATCH (n:Person) WHERE n.name="周星驰" AND n.born=1962 return n;
MATCH (n:Person{name:"周星驰"}) WHERE n.born=1962 return n;

⑤、DELETE
  • DELETE可以删除节点及其关联节点和关系。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20

// 删除与某个节点的关系
match (n:Person{name:"蔡少芬"})-[r]-(m:Movie{title:"大话西游之大圣娶亲"}) delete r;

// 删除与某个节点的关系
match (n:Person{name:"蔡少芬"})-[r]-(m:Movie)
where m.title='大话西游之月光宝盒' delete r;

// 删除 name=莫文蔚 点与所有节点的所有关系链
match (n:Person{name:"莫文蔚"})-[r]-(m:Movie) delete r;

// 删除 name=莫文蔚 的所有关系链,和其本身节点
match (n:Person{name:"莫文蔚"})-[r]-(m:Movie) delete r,n;

// 删除 name=莫文蔚 的所有关系链与本身节点和相关联的节点
// (保证两节点都没有和其他节点有关系才可删除)
match (n:Person{name:"莫文蔚"})-[r]-(m:Movie) delete r,n,m;

// 删除,清库
MATCH (n) DETACH DELETE n;
⑥、REMOVE
  • REMOVE命令用于:
  • 删除节点或关系的标签
  • 删除节点或关系的属性

和DELETE的主要区别

  • DELETE操作用于删除节点和关联关系。
  • REMOVE操作用于删除标签和属性。
1
2
3
4
5
6
7
8
9
10
// 删除 节点name=莫文蔚的born属性
MATCH (n:Person{name:"莫文蔚"}) REMOVE n.born return n

// 和上面一样意思,第二种写法
MATCH (n:Person) where n.name="莫文蔚" REMOVE n.born return n

// 删除 关系类型的 roles 属性
match (n:Person{name:"吴孟达"})-[r]-(m:Movie{title:"大话西游之大圣娶亲"})
REMOVE r.roles
return r,n;
⑦、ORDER BY
  • 和数据库SQL一样,也是排序的意思
  • 例子如下:
1
2
3
4
5
// 查询 Person所有节点,按born升序返回
MATCH (p:Person) return p.born,p.name order by p.born asc

// 查询 Person所有节点,按born降序返回
MATCH (p:Person) return p.born,p.name order by p.born desc
⑧、SET
  • 可以向现有节点或关系添加新属性。
  • 添加或更新属性值
  • 例子如下:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
// 上面删除了吴孟达的关系属性roles,现在重新给他加上
match (n:Person{name:"吴孟达"})-[r]-(m:Movie{title:"大话西游之大圣娶亲"})
SET r.roles=["猪八戒","二师兄"]
// return 这个可加可不加,加的话会查询返回节点,不加就只显示是否更新成功的提示
return n,m;

// 给朱茵这个节点加上一个age属性
match (n:Person{name:"朱茵"})
SET n.age=18
return n;

// 给朱茵这个节点加上多个属性
match (n:Person{name:"朱茵"})
SET n.nickName="紫霞仙子",n.race='仙'
return n;
⑨、UNION
  • UNION的意思是合并,可以将不同的结果合并成一组结果
  • UNION ALL 也是合并,和UNION不同的是:UNION会去重,UNION ALL不会
1
2
3
4
5
6
// 合并 Person类型和Movie类型,不同字段名,所以需要用as 使用别名
MATCH (p:Person)
return p.name as name,p.born as year
UNION ALL
Match (m:Movie)
return m.title as name,m.released as year
⑩、MERGE
  • MERGE 命令检查该节点在数据库中是否可用。避免重复
  • 如果它不存在,它创建新节点。 否则,它不创建新的。
  • 例子:
1
2
3
4
5
6
// 这个是创建节点不成功的,因为Person已经有name=周星驰的节点了
MERGE (zxx:Person {name:'周星驰'})

// 这个命令会创建一个新的节点,因为name=周星驰有了,
// 但是 born=2022这个值不相等,所以会创建新的节点
MERGE (zxx:Person {name:'周星驰',born:2022})

2、其他复合查询

  • 上面已经基本介绍了简单语法,现在来试试把他们组合成复杂语法
  • 例子:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
// 创建意中人关系的A、B节点
MATCH (a:Person { name: '朱茵' })
MATCH (b:Person { name: '周星驰' })
create (a)-[r:Feel {role:"意中人",remark:"紫霞仙子等了至尊宝500年"}]->(b)
return a,b;

// 除了上面的CREATE语法,也可以使用MERGE,加一个牛魔王 如下
MATCH (a:Person { name: '朱茵' })
MATCH (b:Person { name: '周星驰' })
MERGE (c:Person{name:"牛魔王"})-[:Feel{role:"意中人",remark:"第三者,横刀夺爱"}]->(a)-[:Feel{role:"意中人",remark:"紫霞仙子等了至尊宝500年"}]->(b)
RETURN a,b,c;

// 查询Person节点存在nickName 属性的节点
MATCH (p:Person)
WHERE exists(p.nickName)
RETURN p;


// 查询Person节点不存在nickName 属性的节点
MATCH (p:Person)
WHERE not exists(p.nickName)
RETURN p;

// 查询标题以 大 开头的电影节点
MATCH (p:Movie)
WHERE p.title STARTS WITH '大'
RETURN p.title;

// 查询名称以 英 结尾的人物节点
MATCH (p:Person)
WHERE p.name ENDS WITH '英'
RETURN p;

// 查询 标题包含 大 的电影节点
MATCH (p:Movie)
WHERE p.title CONTAINS '大'
RETURN p.title;

// ~ 开头的后面可以使用正则表达式
MATCH (p:Person)
WHERE p.name =~ '周.*'
RETURN p.name;

// OPTIONAL 有点像左连接
MATCH (p:Person)
WHERE p.born>1950
OPTIONAL MATCH (p)-[r]-(other:Movie{title:"大话西游之大圣娶亲"})
RETURN p.name, other.title;

// 查询多组关系,谁 出演电影 又导演电影
MATCH (j:Person)-[r:ACTED_IN]->(m:Movie ),
(j)-[:DIRECTED]-(m),
(p)-[r1:Feel]-(j)
RETURN j.name,m.title,p.name;

// DISTINCT 过滤掉重复的数据
MATCH (j:Person)-[r:ACTED_IN]->(m:Movie ),
(j)-[:DIRECTED]-(m),
(p)-[r1:Feel]-(j)
RETURN DISTINCT j.name,p.name;

// unwind 可以展开然后 通过 as 起一个别名
WITH [1965, 1962] AS list
UNWIND list AS number
MATCH (p:Person{born:number})
RETURN p.name, p.born ORDER BY p.born DESC;

// MERGE ON CREATE 当不存在时执行,否则执行MERGE ON MATCH 分支
MERGE (p:Person {name: '周星驰测试'})-[r:ACTED_IN]-(m:Movie)
ON CREATE SET r.since = date('2018-03-01')
ON MATCH SET r.updated = date()
RETURN p, r, m;

// exists 可以使用{}包起来
match (p:Person)-[r:ACTED_IN]->(m:Movie)
WHERE exists{
match (n:Person)-[r1:Feel]->(p)
}
return p,m;

// 查询朱茵到Movie都经过哪些节点,发现结果和想要的不太对
match p=(n1:Person)-[* 0..5]-(n2:Movie)
where n1.name='朱茵'
return p;

// 查看节点到节点的经过过程是怎样的,因为查的5层,会经过重复节点,所有可以过滤掉重复节点
match p=(n:Person)-[r* 0..5]-(m:Movie)
where n.name='朱茵' and ALL( n1 in nodes(p) where size([n2 in nodes(p) where id(n1) = id(n2)])=1 )
return [n in nodes(p) | coalesce(n.name,n.title)];


// 查询两点之间的最短路径
match p=shortestPath((n1:Person)-[* 0..3]-(n2:Movie))
where n1.name='朱茵'
return p;

// 查询所有最短路径(可能会漏)
match p=allshortestpaths((n1:Person)-[* 0..3]-(n2:Movie))
where n1.name='朱茵'
return p;

// with 可以把之前的查询结果带到下面的查询语句中进行使用
match (n1:Person)-[r * 0..3]-(n2:Movie)
where n1.name='朱茵'
with n1,n2
match p2=(n3)-[r:DIRECTED]->(n2)
return n1,n2,p2


// Call语法简单示例
call{
match (p:Person)-[r:ACTED_IN]->(m:Movie)
WHERE exists{
match (n:Person)-[r1:Feel]->(p)
}
return p
}
with p,[(a)-[:Feel]->(p) | a.name] as tName
return p.name,p.born,tName

3、Cypher函数

  • 常用函数有:

  • 字符串函数

    • toUpper
      • 它用于将所有字母更改为大写字母
    • toLower
      • 它用于将所有字母改为小写字母。
    • coalesce
      • 可以判断字符串是否为空,可以给一个默认值
    • substring
      • 字符串截取
    • replace
      • 它用于替换一个字符串的子字符串。
  • 数字相关函数

    • count
    • max
    • min
    • sum
    • avg
  • 关系函数

    • STARTNODE

      • 它用于知道关系的开始节点。
    • ENDNODE

      • 它用于知道关系的结束节点。
    • ID

      • 它用于知道关系的ID。
    • TYPE

      • 它用于知道字符串表示中的一个关系的TYPE。
  • 其他函数

    • size
      • 用户返回列表集合的个数
    • collect
      • 可以把列的数据收集起来
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
// 朱茵的 eName 大写返回
MATCH (e:Person{name:"朱茵"}) RETURN e.name,e.eName,toUpper(e.eName)

// 朱茵的 eName 小写返回
MATCH (e:Person{name:"朱茵"}) RETURN e.name,e.eName,toLower(e.eName)

// 朱茵的 eName 不存在就给一个 默认值
MATCH (e:Person{name:"朱茵"}) RETURN e.name,coalesce(e.eName,"默认值") as eName

// 字符串截取
MATCH (e:Person{name:"朱茵"}) RETURN e.name,substring(e.nickName,0,1) as eName

// 字符串替换
MATCH (e:Person{name:"朱茵"}) RETURN e.name,replace(e.nickName,"紫霞","紫霞和紫青") as eName

// 查询Person节点包含born属性的节点个数
MATCH (p:Person) RETURN count(p.born);

// 查询Person所有节点个数
MATCH (p:Person) RETURN count(*);

// 求最大值
MATCH (p:Person) RETURN max(p.born);

// 求最小值
MATCH (p:Person) RETURN min(p.born);

// 求和
MATCH (p:Person) RETURN sum(p.born);

// 求平均数
MATCH (p:Person) RETURN avg(p.born);
// 数据聚类
MATCH (p:Person) RETURN count(p.born),max(p.born),min(p.born),sum(p.born),avg(p.born);

// 返回 r 关系的开始节点
MATCH (a)-[r:ACTED_IN]->(b) RETURN STARTNODE(r);

// 返回 r 关系的结束节点
MATCH (a)-[r:ACTED_IN]->(b) RETURN ENDNODE(r);

// 返回 关系的ID 和关系的 类型
MATCH (a)-[r]->(b) RETURN ID(r),TYPE(r),size(r.roles)

// 返回 导演与 收集导演导过的电影剧名titleList
match (a:Person)-[r:DIRECTED]->(m:Movie) RETURN a.name,collect(m.title) as titleList,size(collect(m.title))

4、Cypher索引

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
// 创建一个以 Person类型的name属性为索引
CREATE INDEX pName_index FOR (a:Person) ON (a.name)

// 创建全文索引
CREATE FULLTEXT INDEX titleIndex FOR (n:Movie) ON EACH [n.title]

// 这种查询就会用到上面建立的索引
MATCH (p:Person {name: '周星驰'})
RETURN p.name

// 多个字段属性,建立的索引,也可以叫 复合索引
CREATE INDEX pb_index FOR (a:Person) ON (a.name,a.born)

//显示数据库中都创建了哪些索引
SHOW INDEXES

// 只显示指定字段(id,name, labelsOrTypes, properties, type)的索引列表
SHOW INDEXES YIELD id,name, labelsOrTypes, properties, type

//唯一性约束,创建唯一约束也会隐式创建索引。一个字段已经创建索引后,就不能继续创建索引
CREATE CONSTRAINT uniTile FOR (m:Movie) REQUIRE m.title IS UNIQUE

// 查询唯一性约束
SHOW CONSTRAINTS

// 删除索引
DROP INDEX titleIndex

四、启用APOC

1、社区版安装APOC

  • 如果是下载的是社区版的话,在Neo4j的安装目录下有一个labs目录
  • 直接把labs下的apoc-4.4.0.8-core.jar(不同版本,这里的名称也不同)复制到plugins目录下即可
  • 默认情况下,只启用不使用低级API的一些函数。要启用所有APOC程序,还需要配置
  • conf/neo4j.conf配置文件中添加:dbms.security.procedures.unrestricted=apoc.*
  • 重新启动Neo4j,然后执行命令:RETURN apoc.version()就会返回apoc的版本(说明成功)
  • 或者执行:call apoc.help("apoc"); 返回apoc的函数相关信息

2、桌面版安装APOC

  • 打开桌面版,然后点击项目=> 选择一个数据库=>右边选择Plugins=>找到Apoc安装即可

3、函数使用示例

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
// apoc 的命令帮助文档
call apoc.help('apoc')

// 比如查看格式化的文档
call apoc.help('format')

// 时间格式化
RETURN apoc.date.format(timestamp()) as time,
apoc.date.format(timestamp(),'ms','yyyy-MM-dd') as date,
apoc.date.parse('13.01.1975','s','dd.MM.yyyy') as unixtime,
apoc.date.parse('2017-01-05 13:03:07') as millis

// 加载MYSQL数据库连接并查询
WITH "jdbc:mysql://localhost:3306/northwind?user=root" as url
CALL apoc.load.jdbc(url,"products") YIELD row
RETURN row
ORDER BY row.UnitPrice DESC
LIMIT 20

// 数组属性过滤查询
UNWIND ['紫霞仙子'] AS names
match (n:Person)-[r]-(m:Movie)
where apoc.coll.contains(r.roles,names)
return n,m

4、APOC文件的导入导出

  • 文件的导出导入需要添加配置文件:apoc.conf
  • 新建一个apoc.conf配置文件放在Neo4j安装目录的conf目录下
  • 编辑如下内容,一个是开启导入功能,一个开启导出功能
1
2
apoc.import.file.enabled=true
apoc.export.file.enabled=true
  • 重启Neo4j服务就可以使用相应的导入导出函数
  • Neo4j默认的导入导出目录是在import目录。
  • 可以在neo4j.conf内容中看到:dbms.directories.import=import(可修改)
  • 命令示例:

①、导入:

  • 导入的语法格式:apoc.import.csv(<nodes>, <relationships>, <config>)

    • 是一个对象数组,代表节点,里面有两个属性: fileName、labels
    属性 描述 示例
    fileName 文件所在位置,string类型 'file:/persons.csv'
    labels 节点的标签,是一个数组类型 ['Person', 'Movie']
    • 是一个对象数组,代表关系,里面有两个属性:fileName、type
    属性 描述 示例
    fileName 文件所在位置,string类型 'file:/persons.csv'
    type 关系类型 'WORKS_AT'
    • 是一个对象,代表一些配置项
    属性 类型 默认 描述
    delimiter String 列之间的分隔符字符
    arrayDelimiter String 数组中的分隔符字符
    ignoreDuplicateNodes Boolean false 对于重复的节点,仅加载第一个节点并跳过其余节点(真)或导入失败(假)
    quotationCharacter String
    stringIds Boolean true 将 ID 视为字符串
    skipLines Integer 1 要跳过的行(包括标题)
    ignoreBlankString Boolean false 如果为 true,则忽略具有空白字符串的属性
    ignoreEmptyCellArray Boolean false 如果为 true,则忽略包含单个空字符串的数组属性,如导入工具
    compression Enum[NONE, BYTES, GZIP, BZIP2, DEFLATE, BLOCK_LZ4, FRAMED_SNAPPY] null 允许获取未压缩(值:)或压缩(其他值)的二进制数据。请参阅二进制文件示例NONE
    • 例子如下:
  • 如果是多类型节点加关系的话,用apoc导入好麻烦,感觉用代码快多了

  • 下面时apoc导入的官方示例:

1
2
3
4
5
6
// persons.csv 是存节点的,knows.csv 是建立关系
CALL apoc.import.csv(
[{fileName: 'file:/persons.csv', labels: ['Person']}],
[{fileName: 'file:/knows.csv', type: 'KNOWS'}],
{ arrayDelimiter: ',', stringIds: false}
)

persons.csv

1
2
3
:ID|name:STRING|speaks:STRING[]
1|John|en,fr
2|Jane|en,de

knows.csv

1
2
:START_ID|:END_ID|since:INT
1|2|2016

②、导出:

1
2
//导出数据为movie1.csv文件,点击右边的下载按钮,文件会下载到安装目录的import目录下
CALL apoc.export.csv.all("movies1.csv", {})

五、大数据量导入Neo4j

  • 小数据量,我们可以用Cypher语法导入

  • 千万上亿级别的,推荐使用 neo4j-admin import

    • neo4j-admin 只能用于导入到未使用的数据库中,也就是需要清库
    • 需要把数据转成 csv文件
  • 来看栗子:演员 -出演->电影

  • 我们现在需要准备3个csv文件:演员节点文件、电影节点文件、演员与电影的关系文件

    • 演员节点文件:actors.csv,内容大致如下:

      • personId:ID,username,:LABEL
        tt01111,"周星驰",Actor
        tt02222,"朱茵",Actor
        tt03333,"吴孟达",Actor;Person
        
        1
        2
        3
        4
        5
        6
        7
        8
        9
        10
        11
        12
        13

        - `personId:ID` 中的`:ID`代表是节点的id,之后的关系连接也是用这个字段

        - `username`是这个节点的属性字段:名字,如果需要多个属性,可以往后添加列

        - `:LABEL` 代表生成的节点Label叫什么,如果有多个Lable用`;`隔开

        - 电影节点文件:`movies.csv`,内容如下:

        - ```
        movieId:ID,title,year:int,:LABEL
        tt01,"大话西游之月光宝盒",1994,Movie
        tt02,"大话西游之大圣娶亲",1994,Movie
      • movieId代表节点ID,

      • titleyear:int代码节点的属性,year:int 代表year这个属性是int类型的。

      • :LABEL 和演员节点一样意思,代表生成的节点Label叫什么,后期不再介绍

    • 演员与电影关系文件:rel.csv

      • :START_ID,role,:END_ID,:TYPE
        tt01111,"至尊宝",tt01,ACTED_IN
        tt02222,"紫霞仙子",tt01,ACTED_IN
        tt03333,"二当家",tt01,ACTED_IN
        tt01111,"孙悟空",tt02,ACTED_IN
        
        1
        2
        3
        4
        5
        6
        7
        8
        9
        10
        11
        12

        - `:START_ID` 代表建立关系的开始节点ID

        - `role`就是关系的属性,多个就在后面多加几列即可

        - `:END_ID` 代表建立关系的结束节点ID

        - `:TYPE` 代表关系的Label名称
        - 当文件准备好,我们就可以使用命令导入了,把上面的3个文件放到neo4j安装目录下的`import`目录下
        - 在neo4j安装目录下的bin目录下有:`neo4j-admin` 可执行程序执行它,命令如下:
        - ```bash
        neo4j-admin import --database=neo4j --nodes=import/actors.csv --nodes=import/movies.csv --relationships=import/rel.csv --force=true --skip-duplicate-nodes=true
    • --database 导入到哪个库

    • --nodes 代表存放节点数据的文件,包含header(列头就是属性名)

    • --relationships 代表存放节点之间的关系文件

    • --force 代表在导入之前强制删除任何现有数据库文件

    • --skip-duplicate-nodes 代表 确定是否跳过导入具有相同 ID/组的节点

    • 常用的其他选项参数:

    • --skip-bad-relationships 代表允许跳过引用关系缺失节点ID(找不到节点)

    • --multiline-fields 表示输入源中的字段是否可以跨越多行,即包含换行符

    • --delimiter 表示csv数据中值之间的分隔符

    • 还有很多选项就不一一列举了,可看官方文档:https://neo4j.com/docs/operations-manual/4.4/tools/neo4j-admin/neo4j-admin-import/

  • 导入成功如下:

您的打赏,是我创作的动力!不给钱?那我只能靠想象力充饥了。