1

我希望有人可以帮助我弄清楚为什么对给定数据集的关系属性的批量更新不起作用。数据集中的 id 值是关系的 neo4j ID。tq,是它rpcweight属性。

var batchUpdate = [{"id":281,"tq":8,"rpc":2.4,"weight":84},{"id":283,"tq":5,"rpc":1.25,"weight":10},
{"id":286,"tq":4,"rpc":3.2,"weight":5}];

var nQuery = WITH {batchUpdate} AS stats UNWIND stats AS s MATCH ()-[k:BELONGS_TO]-() WHERE id(k)=s.id SET k.weight=s.weight, k.rpc=s.rpc, k.tq=s.tq;

session
.run(nQuery,{batchUpdate:batchUpdate})
.then(function (result) {
console.log('updated');
})
.catch(function (error) {
console.log('neo4j stats update error ' + error);
});

我没有收到任何错误,它属于成功功能,但实际上没有属性更新。

4

1 回答 1

1

使用官方 neo4j Javascript 驱动程序时,您应该使用neo4j.int()函数来包装通过参数传递的整数值,以解决 Javascript 不支持 64 位整数的事实(而这正是 neo4j 使用的)。默认情况下,Javascript 驱动程序将参数中的整数转换为浮点数。

浮点数将不被视为等于等效整数。

尝试更改您的数组,如下所示:

var neo4j = require('neo4j-driver').v1;

...

var batchUpdate = [
  {"id":neo4j.int(281),"tq":neo4j.int(8),"rpc":2.4, "weight":neo4j.int(84)},
  {"id":neo4j.int(283),"tq":neo4j.int(5),"rpc":1.25,"weight":neo4j.int(10)},
  {"id":neo4j.int(286),"tq":neo4j.int(4),"rpc":3.2, "weight":neo4j.int(5)}
];
于 2019-04-17T23:55:52.763 回答