使用Neo4j .Net驱动程序的结果

时间:2018-01-28 11:47:44

标签: c# .net neo4j .net-core

我正在努力将原生Neo4j .Net驱动程序的INode结果转换为我自己的对象。

public class User
{
    public String UUID { get; set; }
    public String firstname { get; set; }
}

我在Neo4j桌面浏览器中返回的节点:

{
  "UUID": "e0bc991a-1018-4edb-83df-771b8cee4c88",
  "firstname": "John"
}

使用Neo4jClient的C#代码(可行):

var users = client.Cypher
.Match("(p:Person)")
.Return(p => p.As<User>())
.Results.ToList();

使用原生Neo4j .Net驱动程序的C#代码(失败):

var users = new List<User>();
using (var session = _driver.Session())
{
  session.ReadTransaction(tx =>
  {
    var result = tx.Run("MATCH (p:Person) RETURN p").ToList();
    users = result.Select(p => p[0].As<User>()).ToList();
  });
}

我的错误讯息是: System.InvalidCastException:无法将类型为Neo4j.Driver.Internal.Node的对象强制转换为sandbox_neotesting.Models.User类型。

关于我如何解决这个问题的任何指示?我希望找到一个解决方案,我可以直接将结果转换为我的内部模型,不必专门设置每个属性

谢谢! :)

1 个答案:

答案 0 :(得分:3)

这里非常安静,但找到了一个有效的解决方案。我只是序列化节点的属性,然后反序列化为User对象。随意提出改进建议!

var statementText = "MATCH (p:Person) RETURN p";

var users = new List<User>();
using (var session = _driver.Session())
{
    session.ReadTransaction(tx =>
    {
        var result = tx.Run(statementText);
        foreach(var record in result)
        {
            var nodeProps = JsonConvert.SerializeObject(record[0].As<INode>().Properties);
            users.Add(JsonConvert.DeserializeObject<User>(nodeProps));
        }
    });
}