我正在尝试设置一些数据,并且对密码查询相当陌生。我正在做一个项目,其中节点和关系是作为足球队的一部分创建的。
例如,我目前仅在游戏和裁判上创建节点。我的逻辑是我读入比赛的数据,如果裁判不作为节点存在,则创建他/她。如果在未来的比赛中我看到一个已经存在的裁判,我只是将他们与比赛联系起来,而不是创建一个重复的记录。我正在执行以下操作,并想在尝试填充数据之前看看我的逻辑是否有意义。
//JUST CREATED A GAME NODE called $GameNode
//let's search if the referee exists
$queryString = "START n=node({nodeId}) ".
"MATCH (n)<-[:REFEREED]-(x)".
"WHERE x.name = {name}".
"RETURN x";
$query = new Everyman\Neo4j\Cypher\Query($client, $queryString, array('nodeId' => 0, 'name' => $referee['referee_name']));
$result = $query->getResultSet();
$referee = 0;
if (count($result)==0)
{
//create referee as he/she does not exist
$referee= $client->makeNode();
$referee->setProperty('name', $referee['referee_name'])
->save();
}
else
{
//let's point the referee to this law case also
$referee = $client->getNode($result['x']->getProperty('id'));
}
$referee->relateTo($GameNode, 'REFEREED')
->save();
提前谢谢了