指标接口规范


指标 类型的接口提供指标的历史数值,包括部分指标的当日数值,例如发电量。将 指标 类型的接口注册为数据源之前,需按照以下规范对接口进行标准化。


HTTP 请求方法


POST

请求参数


名称

必需/可选

数据类型

描述

orgId

必需

String

指标所属的组织 ID。

mdmIds

必需

String

指标对应的对象实例的标识符,多个对象实例之间用英文逗号隔开。基础查询格式:mdmId1,mdmId2,mdmId3,mdmId4;分组聚合查询格式:mdmId1,mdmId2:group1|mdmId3,mdmId4:group2。

metrics

必需

String

指标的标识符,多个指标之间用英文逗号隔开。

timeGroup

必需

String

指标聚合的时间粒度。支持以下时间粒度:RAW (原始数据),1m(1分钟),5m(5分钟),10m(10分钟),15m(15分钟),30m(30分钟),60m(60分钟),H(小时),D(日),W(周),M(月),Y(年), T(总计), L(最新数据)。

startTime

timeGroupL 时可选,为其他时间粒度时必需

String

采样数据开始时间,格式:YYYY-MM-dd hh:mm:ss

endTime

timeGroupL 时可选,为其他时间粒度时必需

String

采样数据结束时间,格式与开始时间保持一致。

dimensions

可选

String

除资产和时​​间之外的维度,例如:设备型号、设备制造商。

rollup

可选

Boolean

多维度查询时是否进行分级小计。

rollupDimensions

可选

String

多维度查询时需要进行聚合的维度。若置空,则使用 dimensions 的值。

withDimensionName

可选

Boolean

在返回维度标识符时,是否同时返回维度名称,用于 UI 展示。当指定为 true 时,返回的维度名称的命名规则为 {dimensionId}Name,例如对于 alertRule 维度,数据源提供方需在响应结果中提供 alertRuleName 字段。

locale

可选

String

中文:zh-CN, 英文:en-US, 日语:ja-JP,西班牙语:es-ES。默认为 en-US。

filter

可选

String

返回结果按表达式进行过滤。例如:[[{“field”:”field1”,”operator”:”>=”,”value”:”1”},{“field”:”field2”,”operator”:”<=”,”value”:”2”}],[{“field”:”field3”,”operator”:”==”,”value”:”3”}]],该表达式含义为:(field1 >= 1 and field2 <= 2) or (field3=3)。

orderBy

可选

String

返回结果按表达式进行排序。例如:[{“field”:”field1”,”order”:”ASC”}, {“field”:”field2”,”order”:”DESC”}],该表达式含义为:按 field1 升序进行一级排序,并按 field2 降序进行二级排序。

pageSize

可选

Integer

分页查询时单页返回记录的条数。

pageNo

可选

Integer

分页查询时指定页码,默认值为 1。

virtualDimensions

可选

String

指定自定义的维度信息替代 dimensions

响应参数


名称

必然/可能返回

数据类型

描述

mdmId

必然返回

String

指标所属的对象实例的标识符。

time

必然返回

String

数据本地时间标记。

metric

必然返回

Object

指标的时序数据值。

dimension

可能返回

Object

指标的维度信息。

pagination

必然返回

Pagination 结构体

描述分页信息。参见 Pagination 结构体

Pagination 结构体


名称

必然/可能返回

数据类型

描述

pageNo

必然返回

Integer

请求页数,从 1 开始。

pageSize

必然返回

Integer

每页的记录数。

totalSize

必然返回

Integer

记录总数。

请求内容类型


application/x-www-form-urlencoded

返回内容类型


application/json; charset = UTF-8

请求示例


POST {requestURL}?orgId=yourOrgId
Content-Type: application/x-www-form-urlencoded
Payload: mdmIds=yourMdmId&metrics=yourMetrics&startTime=yourStartTime&endTime=yourEndTime&timeGroup=yourTimeGroup

返回示例


{
    "pagination":
     {
        "pageNo": 1,
        "pageSize": 20000,
        "totalSize": 2
    },
    "data": [
        {
            "metrica": 9999.000000,
            "metricb": 0.3717,
            "metricc": 223,
            "dimension1": "dimension1",
            "dimension2": "dimension2",
            "mdmId": "yourMdmId",
            "time": "2019-01"
        },
        {
            "metrica": 9999.000000,
            "metricb": 0.0417,
            "metricc": 25,
            "dimension1": "dimension1",
            "dimension2": "dimension2",
            "mdmId": "yourMdmId",
            "time": "2019-02"
        }
    ],
    "code": 0,
    "msg": "OK"
}