Warning: file_get_contents(/data/phpspider/zhask/data//catemap/7/neo4j/3.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Neo4j 基于密码的模糊搜索_Neo4j_Cypher - Fatal编程技术网

Neo4j 基于密码的模糊搜索

Neo4j 基于密码的模糊搜索,neo4j,cypher,Neo4j,Cypher,我为具有FirstName、LastName属性的用户创建了节点。现在我想从两个站点搜索两个属性中的一些值。让我解释一下 FirstName LastName --------- -------- Manish Pal Pal Dharmesh Rajpal Yadav sharma shreepal 现在我想搜索哪个节点的firstname或lastname包含“pal”。 我写过这样的查询 START users=node(*) WHERE (u

我为具有FirstName、LastName属性的用户创建了节点。现在我想从两个站点搜索两个属性中的一些值。让我解释一下

FirstName  LastName
---------  --------
Manish     Pal
Pal        Dharmesh
Rajpal     Yadav
sharma     shreepal
现在我想搜索哪个节点的firstname或lastname包含“pal”。 我写过这样的查询

START users=node(*) 
WHERE (users.FirstName =~ '(?i)pal.*' OR users.LastName =~ '(?i)pal.*') 
RETURN users;
它只给我2个节点,但我希望所有包含“pal”的节点

如果我试着这样做

START users=node(*) 
WHERE (users.FirstName =~ '(?i)*.pal.*' OR users.LastName =~ '(?i)*.pal.*') 
RETURN users;
它给了我以下的错误

“模式语法异常”

索引4(?i).ant附近悬空的元字符“”^*

我已为你树立了榜样,供你随时参考


谢谢。

第二个查询包含无效的正则表达式语法。我想你的意思是:

START users=node(*) 
WHERE (users.FirstName =~ '(?i).*pal.*' OR users.LastName =~ '(?i).*pal.*') 
RETURN users
请注意您帖子中查询的不同之处:

  • ”(?i)*.pal.*”
    ,以及
  • 在上面的查询中,
    ”(?i)。*pal.*”
星号
*
表示我前面的表达式[星号]可能出现任意次数,包括零次。但是
(?i)
不是正则表达式,只是一个忽略实际表达式大小写的修饰符。我想你的意思是
*
。正则表达式
匹配任何字符,星号允许任何字符出现任意次数

因此,
“(?i)。*pal.*”
说:[忽略大小写]

上述查询为我返回了四个结果:

users.FirstName  | users.LastName
---------------------------------
sharma           | shreepal
Rajpal           | Yadav
Pal              | Dharmesh     
Manish           | Pal

如果我理解正确,这就是你想要的。

我的荣幸:-)如果答案是正确的,你可能会接受它,这样大家都能看到这个问题得到解决。是的。但我不是stackoverflow的普通用户,所以我可以将此问题的状态更改为已接受。你能指引我吗?所以,下一次我会做的。当然要感谢:在答案文本的左侧,您应该看到两个元素:1、答案的当前投票状态(此答案当前为1)和向上或向下投票的箭头。在这个投票状态下,作为提问者,你应该看到一个空洞的复选标记。如果(且仅当)您找到满意的答案,您可以单击此复选标记,该复选标记将变为绿色。然后,你接受了各自的答案。请注意,如果给出多个答案,您只能接受一个答案。我已经这样做了。你看到我的另一个帖子了吗: