cancel
Showing results for 
Search instead for 
Did you mean: 

Head's Up! These forums are read-only. All users and content have migrated. Please join us at community.neo4j.com.

Fuzzy query in cypher =~

ctuniv
Node Link

Hi there ,

I encountered an issue about fuzzy query with cypher that puzzled me for one week.
If I'd like to query a person who has the skill contains C++ (ignore the upper case or lower case) , the query below runs well in desktop browser:
match p = (a:Person {user_id:'18501700312'})-[r0..2]->()-[r1]->(b:Person)
where r1.skill =~ '.
(?i)C++.*'

But it runs with error if I'd like to query a person who has the skill contains C+++ (ignore the upper case or lower case) ,

match p = (a:Person {user_id:'18501700312'})-[r0..2]->()-[r1]->(b:Person)
where r1.skill =~ '.
(?i)C+++.*'

Error msg :
ERROR Neo.ClientError.Statement.SemanticError
Invalid Regex: Dangling meta character '+' near index 9 .(?i)C+++.

I thought + is a special character in cypher , I tried to use escape sign (\) , it does not work well , who can help with this ? Any suggestion would be appreciated , looking forward to your feedback.

1 ACCEPTED SOLUTION

Hi,

Here's an alternative.
It is easy to understand.

CREATE (:Person {name: 'John'})<-[:SKILL {skill: 'Python'}]-(),
       (:Person {name: 'Bob'})<-[:SKILL {skill: 'C'}]-(),
       (:Person {name: 'Jane'})<-[:SKILL {skill: 'C++'}]-(),
       (:Person {name: 'Lisa'})<-[:SKILL {skill: 'c++'}]-(),
       (:Person {name: 'Mike'})<-[:SKILL {skill: 'C+++'}]-(),
       (:Person {name: 'Will'})<-[:SKILL {skill: 'c+++'}]-()
MATCH (a:Person)<-[r1]-()
  WHERE toLower(r1.skill) CONTAINS toLower('C+++')
RETURN a.name, r1.skill

"C+++" and "c+++" are the return values.

a.name	r1.skill
"Mike"	"C+++"
"Will"	"c+++"

View solution in original post

7 REPLIES 7

intouch_vivek
Graph Steward

Try below query for C+++
match p = (a:Person {user_id:'18501700312'})-[r 0..2]->()-[r1]->(b:Person)
where r1.skill =~ '.*(?i)c\+{3}'
Note: There are two backslash rather than one. editor is not displaying it.
Updated the post to incorporate case insensitive

this works well also for this single case , thanks all the same

Could you please explain what do you mean by single case ? So that I can correct myself

Hi,

Here's an alternative.
It is easy to understand.

CREATE (:Person {name: 'John'})<-[:SKILL {skill: 'Python'}]-(),
       (:Person {name: 'Bob'})<-[:SKILL {skill: 'C'}]-(),
       (:Person {name: 'Jane'})<-[:SKILL {skill: 'C++'}]-(),
       (:Person {name: 'Lisa'})<-[:SKILL {skill: 'c++'}]-(),
       (:Person {name: 'Mike'})<-[:SKILL {skill: 'C+++'}]-(),
       (:Person {name: 'Will'})<-[:SKILL {skill: 'c+++'}]-()
MATCH (a:Person)<-[r1]-()
  WHERE toLower(r1.skill) CONTAINS toLower('C+++')
RETURN a.name, r1.skill

"C+++" and "c+++" are the return values.

a.name	r1.skill
"Mike"	"C+++"
"Will"	"c+++"

Really helpful , awesome , it works well , many thanks.

Kindly mark the solution to close it

Really helpful , awesome , it works well , many thanks.