数据模型定义了知识图谱服务中的实体类型和关系类型以及一些附加设置。DataModel 资源允许用户查询实体和关系类型的属性。通过定义这些类型及其属性,数据模型定义了图谱的模式。
知识图谱数据模型示例。
{
"dataModel": {
"declaredClass": "geoscene.rest.knowledgeGraph.DataModel",
"timestamp": {},
"spatialReference": {
"latestWkid": 0,
"wkid": 4326,
"vcsWkid": 0,
"latestVcsWkid": 0
},
"strict": false,
"entityTypes": [
{
"declaredClass": "geoscene.rest.knowledgeGraph.EntityType",
"name": "company",
"alias": "Company",
"role": "Regular",
"strict": false,
"properties": [
{
"declaredClass": "geoscene.rest.knowledgeGraph.GraphProperty",
"name": "Name",
"alias": "Name",
"fieldType": "esriFieldTypeString",
"geometryType": "esriGeometryNull",
"hasM": false,
"hasZ": false,
"nullable": true,
"editable": true,
"required": false,
"defaultVisibility": true,
"systemMaintained": false,
"searchable": false,
"defaultValue": null
},
{
"declaredClass": "geoscene.rest.knowledgeGraph.GraphProperty",
"name": "id",
"alias": "id",
"fieldType": "esriFieldTypeOID",
"geometryType": "esriGeometryNull",
"hasM": false,
"hasZ": false,
"nullable": false,
"editable": false,
"required": true,
"defaultVisibility": true,
"systemMaintained": true,
"searchable": false,
"defaultValue": null
}
],
"fieldIndexes": [
{
"declaredClass": "geoscene.rest.knowledgeGraph.FieldIndex",
"name": "esri__id_idx",
"unique": true,
"ascending": true,
"description": "",
"fieldNames": [
"id"
]
},
{
"declaredClass": "geoscene.rest.knowledgeGraph.FieldIndex",
"name": "geoscene__name_idx",
"unique": true,
"ascending": true,
"description": "",
"fieldNames": [
"name"
]
}
]
}
],
"relationshipTypes": [
{
"declaredClass": "geoscene.rest.knowledgeGraph.RelationshipType",
"name": "employed_bu",
"alias": "Employed By",
"role": "Regular",
"strict": false,
"properties": [
{
"declaredClass": "geoscene.rest.knowledgeGraph.GraphProperty",
"name": "id",
"alias": "id",
"fieldType": "esriFieldTypeGUID",
"geometryType": "esriGeometryNull",
"hasM": false,
"hasZ": false,
"nullable": false,
"editable": false,
"required": true,
"defaultVisibility": true,
"systemMaintained": true,
"searchable": false,
"defaultValue": null
},
{
"declaredClass": "geoscene.rest.knowledgeGraph.GraphProperty",
"name": "start_date",
"alias": "Start Date",
"fieldType": "esriFieldTypeDate",
"geometryType": "esriGeometryNull",
"hasM": false,
"hasZ": false,
"nullable": false,
"editable": false,
"required": true,
"defaultVisibility": true,
"systemMaintained": false,
"searchable": false,
"defaultValue": null
}
],
"fieldIndexes": [
{
"ascending": true,
"description": "index on id field",
"fieldNames": ["id"],
"name": "esri_id_idx",
"unique": "true",
}
],
"originEntityTypes": [
"Person"
],
"destinationEntityTypes": [
"Company"
]
}
]
}
}
- 另请参阅
构造函数
属性概述
名称 | 类型 | 描述 | 类 |
---|---|---|---|
String | 类的名称。 更多详情 | Accessor | |
EntityType[] | 包含在知识图谱中的实体类型列表,包括其关联的属性。 更多详情 | DataModel | |
RelationshipType[] | 知识图谱中的关系类型列表,包括其关联的属性。 更多详情 | DataModel | |
SpatialReference | 指定知识图谱的空间参考信息。 更多详情 | DataModel | |
Boolean | 指示用户是否可以更改数据模型。 更多详情 | DataModel | |
Date | 上次更新数据模型的日期。 更多详情 | DataModel |
属性详细信息
-
类的名称。声明的类名称格式化为
geoscene.folder.className
。
-
entityTypes EntityType[]
-
包含在知识图谱中的实体类型列表,包括其关联的属性。
-
relationshipTypes RelationshipType[]
-
知识图谱中的关系类型列表,包括其关联的属性。
-
spatialReference SpatialReferenceautocast
-
指定知识图谱的空间参考信息。
- 默认值:null
-
strict Boolean
-
指示用户是否可以更改数据模型。如果为
true
,则无法修改数据模型,knowledgeGraphService.executeApplyEdits() 将失败。如果为false
,则任何用户都可对数据模型进行更改。数据模型的 strict 属性只能由管理员或知识图谱服务所有者从 GeoScene REST API 更新 (编辑数据模型) 中进行设置。
-
timestamp Date
-
上次更新数据模型的日期。
方法概述
名称 | 返回值类值 | 描述 | 类 |
---|---|---|---|
添加一个或多个与对象的生命周期相关联的句柄。 更多详情 | Accessor | ||
Boolean | 如果存在指定的句柄组,则返回 true。 更多详情 | Accessor | |
移除对象拥有的句柄组。 更多详情 | Accessor |
方法详细说明
-
addHandles(handleOrHandles, groupKey)inherited
-
添加一个或多个与对象的生命周期相关联的句柄。当对象被销毁时,将移除句柄。
// Manually manage handles const handle = reactiveUtils.when( () => !view.updating, () => { wkidSelect.disabled = false; }, { once: true } ); // Handle gets removed when the object is destroyed. this.addHandles(handle);
参数handleOrHandles WatchHandle|WatchHandle[]对象销毁后,标记为要移除的句柄。
groupKey *optional标识句柄应添加到的组的键。组中的所有句柄稍后都可使用 Accessor.removeHandles() 进行删除。如果未提供键,则句柄将被添加到默认组。
-
如果存在指定的句柄组,则返回 true。
参数groupKey *optional组键。
返回类型 描述 Boolean 如果存在指定的句柄组,则返回 true
。示例// Remove a named group of handles if they exist. if (obj.hasHandles("watch-view-updates")) { obj.removeHandles("watch-view-updates"); }
-
removeHandles(groupKey)inherited
-
移除对象拥有的句柄组。
参数groupKey *optional要移除的组键或组键的数组或集合。
示例obj.removeHandles(); // removes handles from default group obj.removeHandles("handle-group"); obj.removeHandles("other-handle-group");