Arhn - архитектура программирования

Следующая цепочка функций Neo4j APOC в запросе Cypher

Мне нужно организовать в последующую цепочку (1..N вызовы) функции apoc.index.in, примерно так:

MATCH (d:Decision)-[:HAS_VALUE_ON]->(ch:Characteristic) WHERE ch.id = 10
CALL apoc.index.in(ch,'HAS_VALUE_ON','property.2.5:7 AND value:45') YIELD node AS decision

MATCH (decision)-[:HAS_VALUE_ON]->(ch:Characteristic) WHERE ch.id = 23
CALL apoc.index.in(ch,'HAS_VALUE_ON','property.1.8:326 OR property.4:17') YIELD node AS decision

MATCH (decision)-[:HAS_VALUE_ON]->(ch:Characteristic) WHERE ch.id = 19
CALL apoc.index.in(ch,'HAS_VALUE_ON','property.15.3:"mike" OR value:43') YIELD node AS decision

RETURN decision

Как видите, мне нужно отфильтровать набор Decision на основе различных условий, описанных на apoc.index.in, например, таких как 'property.15.3:"mike" OR value:43' и так далее.

Прямо сейчас запрос выше не работает. Можно ли с помощью APOC связать его в цепочку, и если да, не могли бы вы показать пример.

08.05.2018

Ответы:


1

Вы должны быть в состоянии сделать это, если вы можете отправить параметр списка, который содержит карты значений, которые вы планируете использовать. Например, предоставлен параметр списка:

inputs = [{chId:10, predicate:"property.2.5:7 AND value:45"}, {chId:23, predicate:"property.1.8:326 OR property.4:17"}, {chId:19, predicate:"property.15.3:'mike' OR value:43"}]

(вам нужно будет понять вуду, чтобы избежать внутренних кавычек вокруг «майка», правильно учитывая язык, с которым вы работаете)

Затем вы можете использовать следующий запрос:

UNWIND $inputs as input
MATCH (ch:Characteristic) 
WHERE ch.id = input.chId AND ()-[:HAS_VALUE_ON]->(ch)
CALL apoc.index.in(ch,'HAS_VALUE_ON', input.predicate) YIELD node AS decision
RETURN decision

Из-за UNWIND для коллекции каждый элемент коллекции будет иметь свою собственную строку, а последующие MATCH и CALL будут выполняться для каждой строки, поэтому результаты вашего решения должны содержать любое решение, которое соответствует связанным критериям.

08.05.2018
  • Большое спасибо за ответ. Я использую Java, и я попытаюсь реализовать предложенное решение. У меня есть дополнительный вопрос относительно набора результатов: будут ли он содержать решения, отвечающие всем связанным критериям, или решения, соответствующие любому из связанных критериев? Согласно моей бизнес-логике, мне нужен результирующий набор, содержащий только те решения, которые соответствуют всем связанным критериям, представленным в $inputs. 09.05.2018
  • Новые материалы

    Коллекции публикаций по глубокому обучению
    Последние пару месяцев я создавал коллекции последних академических публикаций по различным подполям глубокого обучения в моем блоге https://amundtveit.com - эта публикация дает обзор 25..

    Представляем: Pepita
    Фреймворк JavaScript с открытым исходным кодом Я знаю, что недостатка в фреймворках JavaScript нет. Но я просто не мог остановиться. Я хотел написать что-то сам, со своими собственными..

    Советы по коду Laravel #2
    1-) Найти // You can specify the columns you need // in when you use the find method on a model User::find(‘id’, [‘email’,’name’]); // You can increment or decrement // a field in..

    Работа с временными рядами спутниковых изображений, часть 3 (аналитика данных)
    Анализ временных рядов спутниковых изображений для данных наблюдений за большой Землей (arXiv) Автор: Рольф Симоэс , Жильберто Камара , Жильберто Кейрос , Фелипе Соуза , Педро Р. Андраде ,..

    3 способа решить квадратное уравнение (3-й мой любимый) -
    1. Методом факторизации — 2. Используя квадратичную формулу — 3. Заполнив квадрат — Давайте поймем это, решив это простое уравнение: Мы пытаемся сделать LHS,..

    Создание VR-миров с A-Frame
    Виртуальная реальность (и дополненная реальность) стали главными модными терминами в образовательных технологиях. С недорогими VR-гарнитурами, такими как Google Cardboard , и использованием..

    Демистификация рекурсии
    КОДЕКС Демистификация рекурсии Упрощенная концепция ошеломляющей О чем весь этот шум? Рекурсия, кажется, единственная тема, от которой у каждого начинающего студента-информатика..