将 Azure CosmosDB DocumentDB API 与图形 API 结合使用
Using Azure CosmosDB DocumentDB API with Graph API
我希望能够做的事情:
- 将无模式 JSON 保存到文档
- 任意连接那些文件
- 根据上述连接获取文档的递归树,例如:
{
"name": "Document 1",
"includes": [
{
"name": "Document 2.1"
"includes": [
{
"name": "Document 3",
"includes": []
}
]
},
{
"name": "Document 2.2",
"includes": []
}
]
}
我的设置的当前状态:
- 配置了 Graph (Gremlin) 的 CosmosDB 实例 API
- 可以通过 DocumentDB 创建 (JSON) 个文档 API
- 可以通过 Graph 为文档创建边 API
- 使用 Node.js 个 SDK
问题:
是否可以通过GraphAPI将JSON对象保存为顶点?它允许使用 g.addV('person').property('id', 'thomas').property('firstName', 'Thomas').property('age', 44).property('userid', 1)
创建顶点,但类似 g.addV({ firstName: 'Thomas' })
的东西似乎不起作用。
如果我通过 DocumentDB API 添加文档并通过 Graph API 添加它们之间的边并遍历图形,结果仅包括文档的 ID,不包括其他属性。是否可以以某种方式填充文档?
示例遍历查询:
g.V('03e0576f-2ff7-6109-5ed5-237b43191354').repeat(out('includes')).until(not(out('includes'))).simplePath().dedup().tree().by('id')
此查询的结果:
[{
"03e0576f-2ff7-6109-5ed5-237b43191354": {
"key": "03e0576f-2ff7-6109-5ed5-237b43191354",
"value": {
"7fab4007-c80c-ba21-f5d3-8eb353ea3279": {
"key": "7fab4007-c80c-ba21-f5d3-8eb353ea3279",
"value": {
"eec55fbd-6900-130d-247f-fb437b093711": {
"key": "eec55fbd-6900-130d-247f-fb437b093711",
"value": {}
},
"cfd14a8c-1ac3-6cc3-e2a4-ac3f250478e1": {
"key": "cfd14a8c-1ac3-6cc3-e2a4-ac3f250478e1",
"value": {
"acac136a-3bd4-831c-df6e-e5b95e593b9a": {
"key": "acac136a-3bd4-831c-df6e-e5b95e593b9a",
"value": {}
}
}
}
}
}
}
}
}]
是的,可以通过图形 API 和文档 API 插入文档。但是,Cosmos 需要文档的特定 GraphSON 格式,以便在图形遍历期间获取它们的所有属性。
我建议您查看 Tinkerpop 文档中的两个 Vertex Properties and GraphSON 以开始更好地了解这些主题。
通过 Gremlin 添加文档时,语法是用逗号分隔要添加的所有属性的名称值。试试这个:
g.addV('label', 'human', 'name', 'jesse', 'age', 27)
现在,如果您转到 Azure 门户并执行 SQL 查询 SELECT * FROM c
,您将能够看到 Cosmos 将您的文档转换成的格式。
我希望能够做的事情:
- 将无模式 JSON 保存到文档
- 任意连接那些文件
- 根据上述连接获取文档的递归树,例如:
{
"name": "Document 1",
"includes": [
{
"name": "Document 2.1"
"includes": [
{
"name": "Document 3",
"includes": []
}
]
},
{
"name": "Document 2.2",
"includes": []
}
]
}
我的设置的当前状态:
- 配置了 Graph (Gremlin) 的 CosmosDB 实例 API
- 可以通过 DocumentDB 创建 (JSON) 个文档 API
- 可以通过 Graph 为文档创建边 API
- 使用 Node.js 个 SDK
问题:
是否可以通过GraphAPI将JSON对象保存为顶点?它允许使用
g.addV('person').property('id', 'thomas').property('firstName', 'Thomas').property('age', 44).property('userid', 1)
创建顶点,但类似 g.addV({ firstName: 'Thomas' })
的东西似乎不起作用。如果我通过 DocumentDB API 添加文档并通过 Graph API 添加它们之间的边并遍历图形,结果仅包括文档的 ID,不包括其他属性。是否可以以某种方式填充文档?
示例遍历查询:
g.V('03e0576f-2ff7-6109-5ed5-237b43191354').repeat(out('includes')).until(not(out('includes'))).simplePath().dedup().tree().by('id')
此查询的结果:
[{
"03e0576f-2ff7-6109-5ed5-237b43191354": {
"key": "03e0576f-2ff7-6109-5ed5-237b43191354",
"value": {
"7fab4007-c80c-ba21-f5d3-8eb353ea3279": {
"key": "7fab4007-c80c-ba21-f5d3-8eb353ea3279",
"value": {
"eec55fbd-6900-130d-247f-fb437b093711": {
"key": "eec55fbd-6900-130d-247f-fb437b093711",
"value": {}
},
"cfd14a8c-1ac3-6cc3-e2a4-ac3f250478e1": {
"key": "cfd14a8c-1ac3-6cc3-e2a4-ac3f250478e1",
"value": {
"acac136a-3bd4-831c-df6e-e5b95e593b9a": {
"key": "acac136a-3bd4-831c-df6e-e5b95e593b9a",
"value": {}
}
}
}
}
}
}
}
}]
是的,可以通过图形 API 和文档 API 插入文档。但是,Cosmos 需要文档的特定 GraphSON 格式,以便在图形遍历期间获取它们的所有属性。
我建议您查看 Tinkerpop 文档中的两个 Vertex Properties and GraphSON 以开始更好地了解这些主题。
通过 Gremlin 添加文档时,语法是用逗号分隔要添加的所有属性的名称值。试试这个:
g.addV('label', 'human', 'name', 'jesse', 'age', 27)
现在,如果您转到 Azure 门户并执行 SQL 查询 SELECT * FROM c
,您将能够看到 Cosmos 将您的文档转换成的格式。