0

我正在为我的数据库使用 Node-Neo4j 客户端。我想创建唯一的节点,但我在 Node-Neo4j 的文档中找不到如何做到这一点。我使用下面的逻辑来检查节点是否存在:

person_param = {'name': namesurname, 'userid': userid };
person_node = db.createNode(person_param);

if (!person_node.exists){
   person_node.save(function(err, result){
       //if(err) and if(!err) stuff
   });
}

但是,据我了解,createNode从头开始创建一个新节点,当我使用exists它时,它只是检查新创建的节点是否保存到数据库中。

如何检查具有提供属性的节点是否已存在于 db 中?

提前致谢。

4

1 回答 1

1

我能想到的唯一解决方案如下:

  • 创建你的属性对象
  • 在 Neo4J 实例中查询这些属性
    • 如果返回结果,请使用
    • 否则保存

在代码中:

var person_param = {'name': namesurname, 'userid': userid };
// Build a Cypher query
var query = [
  'MATCH (user: {name: {name}, id: {userid}})',
  'RETURN user'
].join('\n');
// use your params in the query
var params = person_param;

// Send the Cypher query
db.query(query, params, function (err, results) {
  if (err) throw err;
  // no node with such properties found
  if(!results.length){
    saveNode(params, callback)
  } else {
    // carry on with your code...
  }
});

function saveNode(person_param, callback){
  var person_node = db.createNode(person_param);
  person_node.save(function(err, result){
    //if(err) and if(!err) stuff
    // call the callback here
  });
}

这种方法的缺点是您需要为您拥有的每种类型的节点构建一个 Cypher 查询,因为(据我所知)无法将属性名称和值都传递给 Cypher。

于 2014-04-14T11:40:03.200 回答