更新时间:2023-09-21 GMT+08:00

批量添加label(2.2.21)

功能介绍

批量添加label。

URI

POST /ges/v1.0/{project_id}/graphs/{graph_name}/schema/labels/action?action_id=batch-add
表1 路径参数

参数

是否必选

类型

说明

project_id

String

项目ID。获取方法请参见获取项目ID

graph_name

String

图名称。

请求参数

表2 Body参数说明

参数

是否必选

类型

说明

labels

String

元数据label名称。

表3 labels参数说明

参数

是否必选

类型

说明

name

String

label的名称。长度不能超过256,只允许字符,数字, 空格,%,@,#,$,:,?,*,.,+,- 和 _符号。

type

String

Label类别,表示此label用于点或边,取值为“vertex”或“edge”或“all”。默认值为“all”,表示label作用于点和边。

properties

Object

待添加属性数组。数组元素为property,具体参数介绍请见表4

表4 property参数说明

参数

是否必选

类型

说明

name

String

属性名称。

  1. property name的长度不能超过256。
  2. property name不允许包含<, >, &, ASCII码14,15和30。
  3. 同一个label下不允许存在相同的property。

cardinality

String

属性的复合类型,包括:

  • single
  • list
  • set

dataType

String

属性的数据类型。具体请参考表1中的元数据类型。

typeNameCount

否(若dataType为enum,则必选)

String

enum类型参数的总数。由该选项控制typeName的个数。

typeName*

否(若dataType为enum,则必选)

String

enum类型参数名称。例如typeNameCount为2,则参数包含typeName1:science,typeName2:literature。

响应参数

表5 响应Body参数说明

参数

类型

说明

errorMessage

String

系统提示信息。

  • 执行成功时,字段可能为空。
  • 执行失败时,用于显示错误信息。

errorCode

String

系统提示信息。

  • 执行成功时,字段可能为空。
  • 执行失败时,用于显示错误码。

result

String

响应结果。成功时result值为success,失败时值为failed。

data

Object

当批量添加部分失败时,data字段包含失败的label_name以及失败原因。

请求示例

批量添加元数据label,元数据label的名称分别为book和movie,以及两个label的待添加属性数组。

POST http://{SERVER_URL}/ges/v1.0/{project_id}/graphs/{graph_name}/schema/labels/action?action_id=batch-add  
{
    "labels": [
        {
            "name": "book",
            "type": "vertex",
            "properties": [
                {
                    "property": {
                        "name": "title",
                        "cardinality": "single",
                        "dataType": "string"
                    }
                }
            ]
        },
        {
            "name": "movie",
            "type": "vertex",
            "properties": [
                {
                    "property": {
                        "name": "movieid",
                        "cardinality": "single",
                        "dataType": "int"
                    }
                }
            ]
        }
    ]
}

SERVER_URL:图的访问地址,取值请参考业务面API使用限制

响应示例

状态码: 200

成功响应示例

Http Status Code: 200
{
 "result": "success"
}
请求部分成功示例
Http Status Code: 200
{
    "result": "partial success",
    "data": {
        "failed": [
            {
                "cause": "label name is invalid  which can only contain letters, digits, space,%,@,#,$,:,?,*,.,+,- and _",
                "labelName": "book<"
            }
        ]
    }
}

状态码: 400

失败响应示例

Http Status Code: 400
 {
  "errorMessage": "label already exists",
  "errorCode": "GES.8801"
 }

状态码

返回值

说明

400 Bad Request

请求错误。

401 Unauthorized

鉴权失败。

403 Forbidden

没有操作权限。

404 Not Found

找不到资源。

500 Internal Server Error

服务内部错误。

503 Service Unavailable

服务不可用。

错误码

请参见错误码