我有一个Neo4j数据库(2.0.3)。我目前正在使用Cypher在我的数据集上运行一些测试查询。我有一组记录,其中包含一个包含名称数组的属性。我希望能够搜索这个名称数组,同时还使用基本的reg-ex来执行此操作。这在密码中是否完全可能?如果不是,你怎么推荐这个呢?
可以结合这两种查询的东西:
MATCH (s:Record) WHERE "John" IN s.name RETURN s;
MATCH (s:Record) WHERE s.name =~ '(?i).*john.*)' RETURN s;
答案 0 :(得分:9)
考虑以下示例数据:
CREATE (:Record {name: ['John', 'Bob']}),
(:Record {name: ['Alice', 'Johnny']}),
(:Record {name: ['the johnster', 'Charles']}),
(:Record {name: ['Danny', 'Josh']})
如果要查找属性数组name
中任何元素与正则表达式匹配的所有记录,请使用ANY
。如果要查找属性数组name
中所有元素与正则表达式匹配的所有记录,请使用ALL
。我相信你想要前者:
MATCH (s:Record)
WHERE ANY(name IN s.name WHERE name =~ '(?i).*john.*')
RETURN s.name
返回:
s.name
John, Bob
Alice, Johnny
the johnster, Charles