译者言:本文介绍了如何批量删除节点的属性的方法,重点介绍了apoc.create.removeProperties 函数的使用。

今天早些时候,Irfan和我在一个数据集上做实验,运行了一些图形算法的程序,结果节点上多了一些属性,所以,现在我要想办法清理这些属性。

现在的数据情况,可以用下面的语句模拟出来:

CREATE (:Node {name: "Mark", pagerank: 2.302, louvain: 1, lpa: 4 })CREATE (:Node {name: "Michael", degree: 23, triangles: 12, betweeness: 48.70 })CREATE (:Node {name: "Ryan", eigenvector: 2.302, scc: 1, unionFind: 4 })

除了name属性,其他都是算法生成的,我要怎样才能删除这些生成的属性呢?

我可以一次删除一个属性,像下面这样:

MATCH (n:Node)REMOVE n.pagerank

对于其他要删除的属性只要重复这个命令就好,但是这个过程可有点痛苦啊----那么这个过程能自动化吗?当然可以,接下来我们就来看看如何自动化这个过程。

首先,我们需要将每个节点的属性除了name,都放到一个列表中。查询语句如下:

neo4j> MATCH (n:Node)       WITH [k in keys(n) where not k in ["name"]] as keys       RETURN keys;+---------------------------------------+| keys                                  |+---------------------------------------+| ["lpa", "pagerank", "louvain"]        || ["betweeness", "degree", "triangles"] || ["unionFind", "eigenvector", "scc"]   |+---------------------------------------+

接下来我们再来尝试删除这些属性,这次我们的查询语句这么写:

neo4j> MATCH (n:Node)       WITH n, [k in keys(n) where not k in ["name"]] as keys       UNWIND keys AS key       REMOVE n[key];Invalid input '[': expected an identifier character, whitespace, node labels, 'u/U', '{', 'o/O', a property map, a relationship pattern, '.' or '(' (line 4, column 9 (offset: 103))"REMOVE n[key];"

啊偶~, 出错了.....赶快看看APOC是不是有删除的方法,我也不知道APOC中有没有相应的方法,所以,我输入“remove”在APOC库中进行搜索。具体语句如下:

CALL dbms.procedures() YIELD name, signature, descriptionWHERE name starts with "apoc" and description contains "remove"return name, signature, description

运行语句显示下图:

我看到apoc.create.removeProperties方法,应该就是删除属性的,我们先来试一下:

neo4j> MATCH (n:Node)       WITH n, [k in keys(n) where not k in ["name"]] as keys       CALL apoc.create.removeProperties(n, keys) YIELD node       RETURN count(*);+----------+| count(*) |+----------+| 3        |+----------+

我们再来看一下节点上还有哪些属性:

neo4j> MATCH (n:Node)       RETURN keys(n) AS keys;+----------+| keys     |+----------+| ["name"] || ["name"] || ["name"] |+----------+

哦耶,太好了。

虽然属性删除了,但是我还是想再优化一下,看是否能够不在每个节点上调用keys方法,而直接传一个除name之外的属性列表。我们可以先通过下面的语句得到除name之外的所有属性:

neo4j> CALL db.propertyKeys() YIELD propertyKey WHERE propertyKey <> 'name'       RETURN collect(propertyKey);+-----------------------------------------------------------------------------------------+| collect(propertyKey)                                                                                                                                      |+-----------------------------------------------------------------------------------------+| ["degree", "pagerank", "louvain", "lpa", "triangles", "betweeness", "scc", "unionFind"] |+-----------------------------------------------------------------------------------------+

如果我要把那个属性列表传到apoc.create.removeProperties中,只要像下面这样就可以了:

CALL db.propertyKeys() YIELD propertyKey WHERE propertyKey <> 'name'WITH collect(propertyKey) AS propertiesMATCH (n:Node)WITH collect(n) AS nodes, propertiesCALL apoc.create.removeProperties(nodes, properties)YIELD nodeRETURN count(*)

更多的数据

删除小规模数据节点上的属性时,上面的语句是可以正常工作的。但是在大型数据节点上去删除属性时,要怎么做呢?这时apoc.periodic.iterate是你最好的选择。

下面我们先来创建100万个准备删除属性的节点:

CALL apoc.periodic.iterate(  "UNWIND range(0, 1000000) AS id RETURN id",  "CREATE (:Node {name: 'name-' + id, pagerank: 2.302, louvain: 1, lpa: 4 })", {})

现在我们稍微修改一下前面的删除语句,将删除除name之外的所有属性:

neo4j> CALL db.propertyKeys() YIELD propertyKey WHERE propertyKey <> 'name'       WITH collect(propertyKey) AS properties       CALL apoc.periodic.iterate(        "MATCH (n:Node) RETURN n",        "WITH collect(n) AS nodes         CALL apoc.create.removeProperties(nodes, $properties)         YIELD node         RETURN count(*)",        {params: {properties: properties}})       YIELD batches       RETURN batches;+---------+| batches |+---------+| 101     |+---------+

最后,我们再来确认一下,所有属性是否都删除了?

neo4j> MATCH (n:Node)       RETURN keys(n), count(*);+---------------------+| keys(n)  | count(*) |+---------------------+| ["name"] | 1000001  |+---------------------+

OK,完美!

原文链接: https://markhneedham.com/blog/2019/03/14/neo4j-delete-dynamic-properties/

译者言:最后欢迎各位同行留言交流译文中的不足。

原文地址:https://www.jianshu.com/p/f9dfa0d513ca

在Neo4j中删除节点中多个属性的方法的更多相关文章

  1. elasticsearh 中每个节点中需要有相同的插件

    elasticsearh 中每个节点中需要有相同的插件 [2016-09-13 19:25:24,049][INFO ][discovery.zen ] [node02] failed to send ...

  2. linux中删除文件内空白行的几种方法。

    linux中删除文件内空白行的几种方法 有时你可能需要在 Linux 中删除某个文件中的空行.如果是的,你可以使用下面方法中的其中一个.有很多方法可以做到,但我在这里只是列举一些简单的方法. 你可能已 ...

  3. 第7.26节 Python中的@property装饰器定义属性访问方法getter、setter、deleter 详解

    第7.26节 Python中的@property装饰器定义属性访问方法getter.setter.deleter 详解 一.    引言 Python中的装饰器在前面接触过,老猿还没有深入展开介绍装饰 ...

  4. jQuery中删除节点方法remove()、detach()、empty()分析

    jQuery中提供了三种删除节点的方法:remove().detach().empty(),本文详细分析这三种方法. 最容易区分的是empty(),该方法严格上属于“清空节点”,即删除其子节点,自身并 ...

  5. sql server 中删除表中数据truncate和delete的区别(转载自.net学习网)

    我们都知道truncate table可以用来删除整个表的内容,它与delete后面不跟where条件的效果是一样.但除此之外,我们还清楚它们之间有其它的区别吗?本章我们将一起讨论truncate与d ...

  6. JS中删除字符串中的空格

    问题描述:         在进行字符串操作时,由于字符串中存在较多的空格,因此需要考虑取消字符串中的空格 问题解决:       (1)删除字符串中的前导空格(字符串的前面的空格): 注意:这里使用 ...

  7. Oracle中删除用户下所有对象的多种方法

      Oracle删除用户下所有对象的方法未必人人都会,下面就为您介绍两种常用的Oracle删除用户下所有对象的方法,希望对您学习Oracle删除用户方面能有所帮助. 方法1: drop user XX ...

  8. C#实现在foreach遍历中删除集合中的元素(方法总结)

    目录 方法一:采用for循环,并且从尾到头遍历 方法二:使用递归 方法三:通过泛型类实现IEnumerator 在foreach中删除元素时,每一次删除都会导致集合的大小和元素索引值发生变化,从而导致 ...

  9. [转贴]JavaScript中Array(数组)的属性和方法

    数组有四种定义的方式 使用构造函数:var a = new Array();var b = new Array(8); var c = new Array("first", &qu ...

随机推荐

  1. 线程组,action to be taken after a sampler error

    continue:继续运行后面的请求 start next  thread loop:后面的请求不执行,重新循环执行 stop thread:停止所有线程(等待正在执行的线程执行完后,失败的请求后面的 ...

  2. shell编程:向函数中传递参数

    cal.sh sh cal.sh 20 + 10 实现这样传参的函数(shell不是一个严谨的编程语言,参数这种是不用定义的,函数中直接引用,shell执行中直接写) #!/bin/bash # ca ...

  3. python面试题之如何解决验证码的问题,用什么模块,听过哪些人工打码平台?

    如何解决验证码的问题,用什么模块,听过哪些人工打码平台? PIL.pytesser.tesseract模块 平台的话有:(打码平台特殊,不保证时效性) 云打码 挣码 斐斐打码 若快打码 超级鹰 本文首 ...

  4. redis 学习入门篇

    基本概念 redis是一个开源的.使用C语言编写的.支持网络交互的.可基于内存也可持久化的Key-Value数据库(非关系性数据库). redis的特点 速度快,因为数据存在内存中,读写数据的时候都不 ...

  5. codeforces847J Students Initiation 网络流

    题目传送门 题意: 有n个人,m对关系,要求每对关系中,有且仅有一个人给另外一个人送礼物,并且使送出礼物最多的人送的礼物尽可能少.并输出送礼物的方案. 思路:这道题麻烦的是网络流模型的转换(废话). ...

  6. mongoose 常用数据库操作 插入

    项目 db.js var mongoose = require('mongoose'); mongoose.connect('mongodb://127.0.0.1:27017/whhhh', { u ...

  7. redis集群扩容(添加新节点)

    一.创建节点(接上文) 1.在H1服务器/root/soft目录下创建7002目录 2.将7001目录的配置文件redis.conf拷贝到7002,并修改配置文件的端口 3.进入 redis-5.0. ...

  8. Jenkins使用admin修改安全矩阵的时候报错“admin没有Overall/Read权限”

    1.注册完Jenkins,然后使用admin用户登录,报错“admin没有Overall/Read权限”: 2.因为我自己的Jenkins是放在tomcat/webapps的目录下的,所以Jenkin ...

  9. 【JZOJ6435】【luoguP5666】【CSP-S2019】树的重心

    description analysis 需要知道一棵树的重心一定在从根出发的重链上,可以考虑先进行树链剖分弄出重儿子和次重儿子,再倍增维护重儿子 由于重链上有一个或两个重心,接下来求的重心都是深度较 ...

  10. 前端agl分页的写法

    <!-- 分页组件开始 --> <script src="../plugins/angularjs/pagination.js"></script&g ...