Get the code: LearnCypher-ua.cql
Cypher - це мова запитів Neo4j для спрощення роботи з графами. Вона повторює синтаксис SQL та перемішує його з таким собі ascii стилем для відображення структури графа. Цей навчальний матеріал передбачає, що ви вже знайомі із концепцією графів, зобрема що таке вершини та зв'язки між ними.
Відображує запис у графі.
()
Таким чином у запиті позначається пуста вершина. Використовується зазвичай для того, щоб позначити, що вона є, проте це не так вже й важливо для запиту.
(n)
Це вершина, яка має назву n, до неї можна повторно звертатись у запиті. Звернення до вершини n починається з нижнього підкреслення та використовує camelCase (верблюжий регіст).
(p:Person)
Можна також додати ярлик до вершини, в данному випадку - Person. Це як тип / клас / категорія. Назва ярлика починається з великої літери та використовує верблюжу нотацію.
(p:Person:Manager)
Вершина може мати кілька ярликів.
(p:Person {name : 'Théo Gauchoux', age : 22})
Вершина також може мати різні властивості, в данному випадку - name та age. Також мають починатися з великої літери та використовувати верблюжу нотацію.
Наступні типи дозволяється використовувати у властивостях:
Увага! В Cypher не існує типу, що відображає час. Замість нього можна використовувати рядок із визначеним шаблоном або чисельне відображення певної дати.
p.name
За допомогою крапки можна звернутись до властивості вершини.
Сполучають дві вершини
[:KNOWS]
Це зв'язок з ярликом KNOWS. Це такий же самий ярлик як і у вершини. Починається з великої літери та використовує ВЕРХНІЙ_РЕГІСТР_ІЗ_ЗМІЇНОЮ_НОТАЦІЄЮ.
[k:KNOWS]
Це той же самий зв'язок, до якого можна звертатись через змінну k. Можна подалі використовувати у запиті, хоч це і не обов'язково.
[k:KNOWS {since:2017}]
Той же зв'язок, але вже із властивостями (як у вершини), в данному випадку властивість - це since.
[k:KNOWS*..4]
Це структурна інформація, яку використовують шляхи, які розглянуті нижче. В данному випадку, *..4 говорить: “Сумістити шаблон із зв'язком k, що повторюватиметься від одного до чотирьох разів.”
Спосіб поєднувати вершини та зв'язки.
(a:Person)-[:KNOWS]-(b:Person)
Шлях описує, що вершини a та b знають (knows) один одного.
(a:Person)-[:MANAGES]->(b:Person)
Шлях може бути направленим. Цей описує, що а є менеджером b.
(a:Person)-[:KNOWS]-(b:Person)-[:KNOWS]-(c:Person)
Можна створювати ланцюги зі зв'язків. Цей шлях описує друга друга (a знає b, який в свою чергу знає c).
(a:Person)-[:MANAGES]->(b:Person)-[:MANAGES]->(c:Person)
Ланцюг, аналогічно, також може бути направленим. Шлях описує, що a - бос b і супер бос для c.
Шаблони, які часто використовуються (з документації Neo4j):
// Друг-мого-друга
(user)-[:KNOWS]-(friend)-[:KNOWS]-(foaf)
// Найкоротший шлях
path = shortestPath( (user)-[:KNOWS*..5]-(other) )
// Спільна фільтрація
(user)-[:PURCHASED]->(product)<-[:PURCHASED]-()-[:PURCHASED]->(otherProduct)
// Навігація по дереву
(root)<-[:PARENT*]-(leaf:Category)-[:ITEM]->(data:Product)
Створити нову вершину:
CREATE (a:Person {name:"Théo Gauchoux"})
RETURN a
RETURN
дозволяє повернути результат після виконання запиту. Можна повертати кілька значень, наприклад, RETURN a, b
.
Створити новий зв'язок (із двома вершинами):
CREATE (a:Person)-[k:KNOWS]-(b:Person)
RETURN a,k,b
Знайти всі вершини:
MATCH (n)
RETURN n
Знайти вершини за ярликом:
MATCH (a:Person)
RETURN a
Знайти вершини за ярликом та властивістю:
MATCH (a:Person {name:"Théo Gauchoux"})
RETURN a
Знайти вершини відповідно до зв'язків (ненаправлених):
MATCH (a)-[:KNOWS]-(b)
RETURN a,b
Знайти вершини відповідно до зв'язків (направлених):
MATCH (a)-[:MANAGES]->(b)
RETURN a,b
Знайти вершини за допомогою WHERE
:
MATCH (p:Person {name:"Théo Gauchoux"})-[s:LIVES_IN]->(city:City)
WHERE s.since = 2015
RETURN p,state
Можна використовувати вираз MATCH WHERE
разом із операцією CREATE
:
MATCH (a), (b)
WHERE a.name = "Jacquie" AND b.name = "Michel"
CREATE (a)-[:KNOWS]-(b)
Оновити окрему властивість вершини:
MATCH (p:Person)
WHERE p.name = "Théo Gauchoux"
SET p.age = 23
Оновити всі властивості вершини:
MATCH (p:Person)
WHERE p.name = "Théo Gauchoux"
SET p = {name: "Michel", age: 23}
Додати нову властивіcть до вершини:
MATCH (p:Person)
WHERE p.name = "Théo Gauchoux"
SET p + = {studies: "IT Engineering"}
Повісити ярлик на вершину:
MATCH (p:Person)
WHERE p.name = "Théo Gauchoux"
SET p:Internship
Видалити окрему вершину (пов'язані ребра повинні бути видалені перед цим):
MATCH (p:Person)-[relationship]-()
WHERE p.name = "Théo Gauchoux"
DELETE relationship, p
Видалити властивість певної вершини:
MATCH (p:Person)
WHERE p.name = "Théo Gauchoux"
REMOVE p.age
Зверніть увагу, що ключове слово REMOVE
це не те саме, що й DELETE
!
Видалити ярлик певної вершини:
MATCH (p:Person)
WHERE p.name = "Théo Gauchoux"
DELETE p:Person
Видалити всю базу даних:
MATCH (n)
OPTIONAL MATCH (n)-[r]-()
DELETE n, r
Так, це rm -rf /
на мові Cypher !
PROFILE
Перед виконанням, показати план виконання запитів.
COUNT(e)
Порахувати елементи (вершини та зв'язки), що відповідають e.
LIMIT x
Обмежити результат до x перших результатів.
Got a suggestion? A correction, perhaps? Open an Issue on the Github Repo, or make a pull request yourself!
Originally contributed by Théo Gauchoux, and updated by 0 contributor(s).