Neo4j APOC-01-图数据库 apoc 插件介绍
liuian 2024-12-08 16:20 50 浏览
neo4j apoc 系列
Neo4j APOC-01-图数据库 apoc 插件介绍[1]
Neo4j APOC-01-图数据库 apoc 插件安装 neo4j on windows10[2]
Neo4j APOC-03-图数据库 apoc 实战使用使用[3]
Neo4j APOC-04-图数据库 apoc 实战使用使用 apoc.path.spanningTree 最小生成树[4]
neo4j 的 apoc
Neo4j 的 APOC(Awesome Procedures on Cypher)是一个非常强大的 Neo4j 插件,它扩展了 Cypher 查询语言的功能,提供了大量的实用函数和存储过程,极大地增强了 Neo4j 的功能性。
APOC 适用于需要更复杂数据处理和操作的场景,支持各种数据转换、图算法、数据导入/导出、集成外部系统等操作。
1.APOC 的基本功能
APOC 插件包含了以下几类常用功能:
?数据转换和处理:
?支持各种图数据的转换,例如将节点和关系转换为其他格式(JSON、CSV 等),以及对图的结构和数据进行各种操作(过滤、聚合、排序等)。?提供了对集合、字符串、日期等数据类型的操作函数。
?图算法:
?APOC 提供了许多图算法(如最短路径、中心度、PageRank 等),虽然 Neo4j 本身也有图算法库(Graph Data Science),但是 APOC 是一个更加轻量级的选择,适用于简单的图分析任务。
?存储过程:
?提供了丰富的存储过程,例如批量数据插入、更新、删除、导入导出等。?支持对图数据库的各种操作进行封装,并简化复杂操作。
?与外部系统的集成:
?APOC 支持通过 HTTP 访问外部 REST API,或者与文件系统交互(如上传、下载文件),以便集成外部数据源。?也支持与外部数据库的连接,如导入其他数据库的数据到 Neo4j。
总结
APOC 是一个功能丰富且灵活的 Neo4j 插件,它为 Cypher 查询语言提供了大量实用的扩展,涵盖了数据处理、图算法、外部系统集成等方面。
通过使用 APOC,开发者可以大大提高图数据库的操作效率和灵活性,尤其是在复杂的数据处理和分析任务中。
apoc 常用的功能
下面是一些常用的 APOC 插件功能和示例
功能 | 存储过程/函数 | 描述 | 示例 |
数据转换 | apoc.convert.toJson() | 将节点、关系或任何图数据结构转换为 JSON 格式 | MATCH (n:Person) RETURN apoc.convert.toJson(n) |
集合操作 | apoc.coll.flatten() | 将嵌套的集合扁平化 | RETURN apoc.coll.flatten([[1, 2], [3, 4]]) |
apoc.coll.sum() | 计算集合中所有元素的和 | RETURN apoc.coll.sum([1, 2, 3, 4]) | |
apoc.text.join() | 将集合中的元素连接成一个字符串 | RETURN apoc.text.join(['a', 'b', 'c'], ',') | |
图算法 | apoc.algo.shortestPath() | 计算两个节点之间的最短路径 | MATCH (start:Person {name: 'Alice'}), (end:Person {name: 'Bob'}) CALL apoc.algo.shortestPath(start, end, 'KNOWS') YIELD path RETURN path |
apoc.algo.dijkstra() | Dijkstra 算法计算最短路径 | MATCH (start:Person {name: 'Alice'}), (end:Person {name: 'Bob'}) CALL apoc.algo.dijkstra(start, end, 'KNOWS') YIELD path RETURN path | |
导入/导出数据 | apoc.import.csv() | 从 CSV 文件导入数据 | CALL apoc.import.csv('file:///path/to/file.csv', {header:true}) YIELD nodes, relationships RETURN nodes |
apoc.export.csv.all() | 将所有图数据导出为 CSV 文件 | CALL apoc.export.csv.all('file:///output.csv', {}) | |
apoc.load.csv() | 从 CSV 文件中加载数据 | CALL apoc.load.csv('file:///path/to/file.csv') YIELD map RETURN map | |
apoc.load.json() | 从外部 URL 加载 JSON 数据 | CALL apoc.load.json('http://example.com/data.json') YIELD value RETURN value | |
外部系统集成 | apoc.load.xml() | 从外部 URL 加载 XML 数据 | CALL apoc.load.xml('http://example.com/data.xml') YIELD value RETURN value |
apoc.load.http() | 通过 HTTP 请求获取外部数据 | CALL apoc.load.http('http://example.com/api') YIELD value RETURN value | |
日期和时间处理 | apoc.date.convert() | 将日期时间字符串转换为时间戳 | RETURN apoc.date.convert('2024-11-01T12:00:00', 'ISO_8601', 'milliseconds') |
图数据操作 | apoc.create.node() | 创建节点并为其设置属性 | CALL apoc.create.node(['Person'], {name: 'Alice', age: 30}) YIELD node RETURN node |
apoc.create.relationship() | 创建关系并设置属性 | MATCH (a:Person {name: 'Alice'}), (b:Person {name: 'Bob'}) CALL apoc.create.relationship(a, 'KNOWS', {since: 2020}) YIELD rel RETURN rel | |
事务和批量操作 | apoc.periodic.iterate() | 按批次进行迭代处理 | CALL apoc.periodic.iterate('MATCH (n:Person) RETURN n', 'SET n.processed = true', {batchSize: 1000}) YIELD batches, total RETURN batches, total |
性能监控与统计 | apoc.stats() | 返回数据库的统计信息 | RETURN apoc.stats() |
路径和图遍历 | apoc.path.expand() | 扩展路径,获取指定节点的邻居 | MATCH (a:Person {name: 'Alice'}) CALL apoc.path.expand(a, 'KNOWS', 1) YIELD path RETURN path |
apoc.path.subgraphNodes() | 获取路径的子图节点 | MATCH (a:Person {name: 'Alice'}) CALL apoc.path.subgraphNodes(a, {relationshipFilter: 'KNOWS'}) YIELD node RETURN node | |
字符串处理 | apoc.text.split() | 按指定分隔符将字符串分割成多个部分 | RETURN apoc.text.split('a,b,c,d', ',') |
apoc.text.replace() | 在字符串中进行替换操作 | RETURN apoc.text.replace('Hello World', 'World', 'Neo4j') |
这些功能覆盖了图数据库的许多常见操作,如数据转换、导入导出、图算法、路径计算等,能够有效扩展 Neo4j 的使用场景。
参考资料
https://www.cnblogs.com/liaozk/p/17138133.html
https://www.w3cschool.cn/neo4j/neo4j_cql_introduction.html
References
[1] Neo4j APOC-01-图数据库 apoc 插件介绍: https://houbb.github.io/2018/01/08/neo4j-plugins-apoc-01-intro
[2] Neo4j APOC-01-图数据库 apoc 插件安装 neo4j on windows10: https://houbb.github.io/2018/01/08/neo4j-plugins-apoc-02-windows10-install-plugins
[3] Neo4j APOC-03-图数据库 apoc 实战使用使用: https://houbb.github.io/2018/01/08/neo4j-plugins-apoc-03-basic-usage
[4] Neo4j APOC-04-图数据库 apoc 实战使用使用 apoc.path.spanningTree 最小生成树: https://houbb.github.io/2018/01/08/neo4j-plugins-apoc-04-minist-tree
相关推荐
-
- 驱动网卡(怎么从新驱动网卡)
-
网卡一般是指为电脑主机提供有线无线网络功能的适配器。而网卡驱动指的就是电脑连接识别这些网卡型号的桥梁。网卡只有打上了网卡驱动才能正常使用。并不是说所有的网卡一插到电脑上面就能进行数据传输了,他都需要里面芯片组的驱动文件才能支持他进行数据传输...
-
2026-01-30 00:37 liuian
- win10更新助手装系统(微软win10更新助手)
-
1、点击首页“系统升级”的按钮,给出弹框,告诉用户需要上传IMEI码才能使用升级服务。同时给出同意和取消按钮。华为手机助手2、点击同意,则进入到“系统升级”功能华为手机助手华为手机助手3、在检测界面,...
- windows11专业版密钥最新(windows11专业版激活码永久)
-
Windows11专业版的正版密钥,我们是对windows的激活所必备的工具。该密钥我们可以通过微软商城或者通过计算机的硬件供应商去购买获得。获得了windows11专业版的正版密钥后,我...
-
- 手机删过的软件恢复(手机删除过的软件怎么恢复)
-
操作步骤:1、首先,我们需要先打开手机。然后在许多图标中找到带有[文件管理]文本的图标,然后单击“文件管理”进入页面。2、进入页面后,我们将在顶部看到一行文本:手机,最新信息,文档,视频,图片,音乐,收藏,最后是我们正在寻找的[更多],单击...
-
2026-01-29 23:55 liuian
- 一键ghost手动备份系统步骤(一键ghost 备份)
-
步骤1、首先把装有一键GHOST装系统的U盘插在电脑上,然后打开电脑马上按F2或DEL键入BIOS界面,然后就选择BOOT打USDHDD模式选择好,然后按F10键保存,电脑就会马上重启。 步骤...
- 怎么创建局域网(怎么创建局域网打游戏)
-
1、购买路由器一台。进入路由器把dhcp功能打开 2、购买一台交换机。从路由器lan端口拉出一条网线查到交换机的任意一个端口上。 3、两台以上电脑。从交换机任意端口拉出网线插到电脑上(电脑设置...
- 精灵驱动器官方下载(精灵驱动手机版下载)
-
是的。驱动精灵是一款集驱动管理和硬件检测于一体的、专业级的驱动管理和维护工具。驱动精灵为用户提供驱动备份、恢复、安装、删除、在线更新等实用功能。1、全新驱动精灵2012引擎,大幅提升硬件和驱动辨识能力...
- 一键还原系统步骤(一键还原系统有哪些)
-
1、首先需要下载安装一下Windows一键还原程序,在安装程序窗口中,点击“下一步”,弹出“用户许可协议”窗口,选择“我同意该许可协议的条款”,并点击“下一步”。 2、在弹出的“准备安装”窗口中,可...
- 电脑加速器哪个好(电脑加速器哪款好)
-
我认为pp加速器最好用,飞速土豆太懒,急速酷六根本不工作。pp加速器什么网页都加速,太任劳任怨了!以上是个人观点,具体性能请自己试。ps:我家电脑性能很好。迅游加速盒子是可以加速电脑的。因为有过之...
- 任何u盘都可以做启动盘吗(u盘必须做成启动盘才能装系统吗)
-
是的,需要注意,U盘的大小要在4G以上,最好是8G以上,因为启动盘里面需要装系统,内存小的话,不能用来安装系统。内存卡或者U盘或者移动硬盘都可以用来做启动盘安装系统。普通的U盘就可以,不过最好U盘...
- u盘怎么恢复文件(u盘文件恢复的方法)
-
开360安全卫士,点击上面的“功能大全”。点击文件恢复然后点击“数据”下的“文件恢复”功能。选择驱动接着选择需要恢复的驱动,选择接入的U盘。点击开始扫描选好就点击中间的“开始扫描”,开始扫描U盘数据。...
- 系统虚拟内存太低怎么办(系统虚拟内存占用过高什么原因)
-
1.检查系统虚拟内存使用情况,如果发现有大量的空闲内存,可以尝试释放一些不必要的进程,以释放内存空间。2.如果系统虚拟内存使用率较高,可以尝试增加系统虚拟内存的大小,以便更多的应用程序可以使用更多...
-
- 剪贴板权限设置方法(剪贴板访问权限)
-
1、首先打开iphone手机,触碰并按住单词或图像直到显示选择选项。2、其次,然后选取“拷贝”或“剪贴板”。3、勾选需要的“权限”,最后选择开启,即可完成苹果剪贴板权限设置。仅参考1.打开苹果手机设置按钮,点击【通用】。2.点击【键盘】,再...
-
2026-01-29 21:37 liuian
- 平板系统重装大师(平板重装win系统)
-
如果你的平板开不了机,但可以连接上电脑,那就能好办,楼主下载安装个平板刷机王到你的个人电脑上,然后连接你的平板,平板刷机王会自动识别你的平板,平板刷机王上有你平板的我刷机包,楼主点击下载一个,下载完成...
- 联想官网售后服务网点(联想官网售后服务热线)
-
联想3c服务中心是联想旗下的官方售后,是基于互联网O2O模式开发的全新服务平台。可以为终端用户提供多品牌手机、电脑以及其他3C类产品的维修、保养和保险服务。根据客户需求层次,联想服务针对个人及家庭客户...
- 一周热门
- 最近发表
- 标签列表
-
- python判断字典是否为空 (50)
- crontab每周一执行 (48)
- aes和des区别 (43)
- bash脚本和shell脚本的区别 (35)
- canvas库 (33)
- dataframe筛选满足条件的行 (35)
- gitlab日志 (33)
- lua xpcall (36)
- blob转json (33)
- python判断是否在列表中 (34)
- python html转pdf (36)
- 安装指定版本npm (37)
- idea搜索jar包内容 (33)
- css鼠标悬停出现隐藏的文字 (34)
- linux nacos启动命令 (33)
- gitlab 日志 (36)
- adb pull (37)
- python判断元素在不在列表里 (34)
- python 字典删除元素 (34)
- vscode切换git分支 (35)
- python bytes转16进制 (35)
- grep前后几行 (34)
- hashmap转list (35)
- c++ 字符串查找 (35)
- mysql刷新权限 (34)
