1

我正在使用 node-neo4j 连接到 neo4j 图形数据库。我注意到,每当我尝试获取所有节点(例如用户)时,json 结果返回包含太多我不需要的信息。

这是返回所有用户节点的代码:

User.getAll = function (callback) {
    var query = [
       'MATCH (user:User)',
       'RETURN user',
    ].join('\n');

    db.query(query, null, function (err, results) {
        if (err) return callback(err);
        var users = results.map(function (result) {
           return new User(result['user']);
        });
        callback(null, users);
    });
 };

它给了我这些json响应;

[
{
    "_node": {
        "_nodeNeo4j": {
            "version": "1.1.0",
            "constructor": "Node"
        },
        "_data": {
            "extensions": {},
            "outgoing_relationships": "http://localhost:7474/db/data/node/13/relationships/out",
            "labels": "http://localhost:7474/db/data/node/13/labels",
            "all_typed_relationships": "http://localhost:7474/db/data/node/13/relationships/all/{-list|&|types}",
            "traverse": "http://localhost:7474/db/data/node/13/traverse/{returnType}",
            "self": "http://localhost:7474/db/data/node/13",
            "property": "http://localhost:7474/db/data/node/13/properties/{key}",
            "properties": "http://localhost:7474/db/data/node/13/properties",
            "outgoing_typed_relationships": "http://localhost:7474/db/data/node/13/relationships/out/{-list|&|types}",
            "incoming_relationships": "http://localhost:7474/db/data/node/13/relationships/in",
            "create_relationship": "http://localhost:7474/db/data/node/13/relationships",
            "paged_traverse": "http://localhost:7474/db/data/node/13/paged/traverse/{returnType}{?pageSize,leaseTime}",
            "all_relationships": "http://localhost:7474/db/data/node/13/relationships/all",
            "incoming_typed_relationships": "http://localhost:7474/db/data/node/13/relationships/in/{-list|&|types}",
            "data": {
                "uid": "53c7a820-f0b4-11e3-af63-28373723792e",
                "name": "user1"
            }
        }
    }
},

无论如何只从密码返回结果的“数据”部分?或者我应该在将结果返回给客户端之前去除 node.js 服务器中不需要的部分吗?

谢谢!

4

3 回答 3

2

我设法通过更改返回的响应来仅返回数据字段,如下所示

User.getAll = function (callback) {
var query = [
    'MATCH (user:User)',
    'RETURN user',
].join('\n');

db.query(query, null, function (err, results) {
       if (err) return callback(err);
       var users = results.map(function (result) {
          return new User(result['user']['data']);
       });
       callback(null, users);
    });
};

我更改了return new User(result['user']['data'])并成功返回了响应的“数据”部分。

于 2014-06-10T17:44:57.550 回答
1

您可以更新查询以返回字段而不是节点...

...
RETURN user.uid, user.name

这将使您的结果集更像是字段的数据“网格” - 但听起来这就是您正在寻找的

于 2014-06-10T17:15:46.670 回答
0

上周我自己也在为此苦苦挣扎。长话短说,您可以将变量设置为 JSON 的特定部分,如下所示:

var anything =JSON.stringify(results[0]._node._data.data);那条线{\"uid\":\"53c7a820-f0b4-11e3-af63-28373723792e\",\"name\":\"user1\"}为我返回。在这里查看我的示例,尝试解释 Node-Neo4j API。顺便说一句,我必须]在 JSON 中添加一个关闭才能使其正常工作。

于 2014-06-18T01:10:08.967 回答