您可以(取决于您的感受)尝试使用动态,例如,您可以像这样设置它:
var dog = new Dog {Name = "Woofer", Breed = "Afghan Hound"};
var owner = new Person {Name = "Jeff", PhoneNumber = "01234567890"};
//CREATE
gc.Cypher.
Create("(owner:Person {ownerParams})")
.WithParam("ownerParams", owner)
.With("owner")
.Create("(owner)-[:HAS_PET]->(dog:Dog {dogParams})")
.WithParam("dogParams", dog)
.ExecuteWithoutResults();
并检索:
//RETURN
var query = gc.Cypher
.Match("(p:Person)-[:HAS_PET]->(d:Dog)")
.Return((p, d) => new {Person = p.As<Node<string>>(), Dog = d.As<Node<string>>()});
var results = query.Results.ToList();
foreach (var result in results)
{
dynamic p = JsonConvert.DeserializeObject<dynamic>(result.Person.Data);
dynamic d = JsonConvert.DeserializeObject<dynamic>(result.Dog.Data);
Console.WriteLine("If you find {0} (a {1}) please call {2} on {3}.", d.Name, d.Breed, p.Name, p.PhoneNumber);
}
显然在这种情况下我would知道我要返回的类型。现在,你会注意到我正在使用Node<string>
在这个 - 哪个一般来说令人皱眉 - 我使用它的原因是它去掉了 Neo4j 返回的所有正常内容,并将Data
出来——这才是我真正感兴趣的。
您可能会尝试这样做:
.Return((p,d) => new {Person = p.As<dynamic>(), Dog = d.As<dynamic>()});
但你最终会遇到的问题是 Neo4jClient 不处理动态并且实际上会将其作为object
这会失去你所有的财产。
这至少应该为您提供一个起点,如果您需要特定类型查询的帮助,那么值得将查询提出来以供参考。