В этом примере показано, как пересечь график и исследовать его структуру с помощью интерфейса MATLAB® для Neo4j®. Для получения дополнительной информации об интерфейсе MATLAB к Neo4j, смотрите Рабочий процесс Базы данных Графика для Интерфейсов БД Neo4j.
Примите, что вам сохранили данные о графике в базе данных Neo4j, которая представляет социальное окружение. Эта база данных имеет семь узлов и восемь отношений. Каждый узел имеет только один ключ name
уникального свойства со значением в пределах от
User1
через User7
. Каждое отношение имеет тип knows
.
Локальная машина размещает базу данных Neo4j с номером порта 7474
, имя пользователя neo4j
, и пароль matlab
. Этот рисунок обеспечивает визуальное представление данных в базе данных.
Создайте объект neo4jconn
связи Neo4j использование
http://localhost:7474/db/data
URL, имя пользователя
neo4j
, и пароль matlab
.
url = 'http://localhost:7474/db/data'; username = 'neo4j'; password = 'matlab'; neo4jconn = neo4j(url,username,password);
Проверяйте Message
свойство объекта neo4jconn
связи Neo4j. Пустой
Message
свойство указывает на успешную связь.
neo4jconn.Message
ans = []
Найдите все метки узла в базе данных Neo4j с помощью объекта neo4jconn
связи Neo4j.
nlabels = nodeLabels(neo4jconn)
nlabels = 1×1 cell array
{'Person'}
Найдите все типы связей в базе данных Neo4j.
reltypes = relationTypes(neo4jconn)
reltypes = 1×1 cell array
{'knows'}
Найдите, что свойство вводит базу данных Neo4j.
propkeys = propertyKeys(neo4jconn)
propkeys = 15×1 cell array
{'Name' }
{'property' }
{'title' }
{'Description'}
{'EndNodes' }
{'Location' }
{'EndDate' }
{'Address' }
{'Project' }
{'Department' }
{'StartDate' }
{'Title' }
{'Date' }
{'Weight' }
{'name' }
Ищите все узлы с меткой Person
узла.
nodesinfo
выходной аргумент содержит метки узла, данные об узле и Neo4jNode
объекты для каждого совпадающего узла.
nlabel = 'Person';
nodesinfo = searchNode(neo4jconn,nlabel)
nodesinfo=7×3 table
NodeLabels NodeData NodeObject
__________ ____________ ___________________________________
0 'Person' [1×1 struct] [1x1 database.neo4j.http.Neo4jNode]
1 'Person' [1×1 struct] [1x1 database.neo4j.http.Neo4jNode]
2 'Person' [1×1 struct] [1x1 database.neo4j.http.Neo4jNode]
3 'Person' [1×1 struct] [1x1 database.neo4j.http.Neo4jNode]
4 'Person' [1×1 struct] [1x1 database.neo4j.http.Neo4jNode]
5 'Person' [1×1 struct] [1x1 database.neo4j.http.Neo4jNode]
9 'Person' [1×1 struct] [1x1 database.neo4j.http.Neo4jNode]
Ищите узел с идентификатором узла 2
. nodeinfo
выходной аргумент содержит идентификатор узла, данные об узле и метки узла для узла с идентификатором узла 2
.
nodeid = 2; nodeinfo = searchNodeByID(neo4jconn,nodeid)
nodeinfo = Neo4jNode with properties: NodeID: 2 NodeData: [1×1 struct] NodeLabels: 'Person'
Ищите входящие типы связей, которые принадлежат узлу nodeinfo
.
nodereltypes = nodeRelationTypes(nodeinfo,'in')
nodereltypes = 1×1 cell array
{'knows'}
Ищите степень всех входящих отношений, которые принадлежат узлу nodeinfo
.
degree = nodeDegree(nodeinfo,'in')
degree = struct with fields:
knows: 1
Ищите отношение с идентификатором узла 4
.
relationid = 4; relationinfo = searchRelationByID(neo4jconn,relationid)
relationinfo = Neo4jRelation with properties: RelationID: 4 RelationData: [1×1 struct] StartNodeID: 3 RelationType: 'knows' EndNodeID: 5
Ищите все входящие отношения, которые принадлежат узлу nodeinfo
. relinfo
выходной аргумент содержит данные об узлах начала и конца и всех совпадающих отношениях от узла источника.
relinfo = searchRelation(neo4jconn,nodeinfo,'in')
relinfo = struct with fields:
Origin: 2
Nodes: [2×3 table]
Relations: [1×5 table]
Получите целый график с помощью узла, маркирует nlabels
.
graphinfo = searchGraph(neo4jconn,nlabels)
graphinfo = struct with fields:
Nodes: [7×3 table]
Relations: [8×5 table]
graphinfo
содержит данные об узле для всех узлов начала и конца для каждого совпадающего отношения. graphinfo
также содержит данные об отношении для каждого совпадающего отношения.
close(neo4jconn)
neo4j
| nodeDegree
| nodeLabels
| nodeRelationTypes
| propertyKeys
| relationTypes
| searchNode
| searchNodeByID
| searchRelation
| searchRelationByID