Возможно ли в настоящее время сделать запросы на совпадение пересечений в redis-графе?
Возможно ли в настоящее время сделать запрос в RedisGraph для пересечений совпадений, учитывая текущие ограничения Cypher?
Например, что-то эквивалентное следующему сценарию Cypher, который вернул бы страны, которые посетили и Мор Йешарим, и Ноам Натив:
MATCH (p:Person)-[x:VISITED]->(c:Country)
WHERE p.name = 'Mor Yesharim' OR p.name = 'Noam Nativ'
WITH c, count(DISTINCT p) as cnt
WHERE cnt = 2
RETURN c
1 ответ
Решение
Ваш предоставленный пример может быть переписан в одном шаблоне, например так:
MATCH (p:Person)-[:VISITED]->(c:Country)<-[:VISITED]-(q:person)
WHERE p.name = 'Mor Yesharim' AND q.name = 'Noam Nativ'
RETURN c
Однако это не подходит для более сложных моделей (если Country
было больше 2, например). В этих случаях вы можете комбинировать WITH
и соответствие ID:
MATCH (p:Person)-[:VISITED]->(c:Country)
WHERE p.name = 'Mor Yesharim' WITH c AS first
MATCH (q:Person)-[:VISITED]->(d:Country)
WHERE q.name = 'Noam Nativ'
AND ID(first) = ID(d)
RETURN d