public void AddRelationshipTest()
{
var conn = Neo4JConn.Connect();
Team obj = new Team();
int id1 = 1, id2 = 2;
NodeReference<Team> sTm = (NodeReference<Team>)ds.GetNodeReference<Team>(id1, conn, obj);
NodeReference<Team> dTm = (NodeReference<Team>)ds.GetNodeReference<Team>(id2, conn, obj);
ReportsToData data = new ReportsToData();
data.SinceYear = 2008;
reportsTo relation = new reportsTo(dTm, data);
conn.CreateRelationship(sTm, relation);
}
其中Get NodeRefernce是一个返回节点引用并且工作正常的方法。 Team是具有节点数据成员的类 当我使用CreateRelationship时,它会创建一个关系 我主要担心的是,即使源节点和目标节点之间已存在关系,它也会创建关系。 我想在两个节点之间创建一个独特的关系,就像
一样graphClient.Cypher
.Match("(user1:User)", "(user2:User)")
.Where((User user1) => user1.Id == 123)
.AndWhere((User user2) => user2.Id == 456)
.CreateUnique("user1-[:FRIENDS_WITH]->user2")
.ExecuteWithoutResults();
但是这里FRIENDS_WITH(任何关系)我必须硬编码,所以我不想使用它。
如何使用Neo4jClient进行操作?
答案 0 :(得分:0)
我不确定问题是什么,.CreateUnique
为什么不只是使用string.Format
或字符串插值来对代码进行硬编码?
public void CreateRelationship(IGraphClient graphClient, string relationshipName)
{
graphClient.Cypher
.Match("(user1:User)", "(user2:User)")
.Where((User user1) => user1.Id == 123)
.AndWhere((User user2) => user2.Id == 456)
.CreateUnique($"(user1)-[:{relationshipName}]->(user2)") //<-- here
.ExecuteWithoutResults();
}
显然可能是:
.CreateUnique(string.Format("(user1)-[:{0}]->(user2)", relationshipName))
如果你真的想要,甚至只使用+
:
.CreateUnique("(user1)-[:" + relationshipName + "]->(user2)")
你 肯定会使用Cypher技术,而不使用NodeReference<T>