data 及其子资源提供了对数据的查询和操作的功能,本文的例子将介绍对数据集中的字段进行统计的过程。

数据集中字段的统计通过对 statistic 资源执行 GET 请求来进行,请参见 statistic 资源页面

本例对 World 数据源中的 Countries 数据集进行统计,Countries 数据集中有 POP_1994 字段,本例对该字段进行统计,获取 1994 年的世界人口情况。通过对如下 URI 执行不同的 GET 请求来实现:

http://localhost:8090/iserver/services/components-rest/rest/data/datasources/name/World/datasets/name/Countries/fields/POP_1994/{statisticMode}.json

URI 中,不同的 {statisticMode}表示不同的统计内容,获取最大值用 MAX,和用 SUM,平均值用 AVERAGE。

示例代码如下:

//统计 1994 年的世界人口

function FieldStatistic()

{

        var commit=getcommit();

        var baseuri="http://localhost:8090/iserver/services/components-rest/rest/data/datasources/name/World/datasets/name/Countries/fields/POP_1994";

        //获取数据集中该字段的最大值。

        commit.open("GET",encodeURI(baseuri+"/MAX.json"),false,"","");

        commit.setRequestHeader("Content-Type", "application/x-www-form-urlencoded; charset=UTF-8");

        commit.send(null);

        //解析从服务器端返回的 json 字符串,解析为一个 JavaScript 对象。

        var response = json_parse(commit.responseText, null);  

        var max=response.result;

        //获取数据集中该字段的和。

        commit.open("GET",encodeURI(baseuri+"/SUM.json"),false,"","");

        commit.setRequestHeader("Content-Type", "application/x-www-form-urlencoded; charset=UTF-8");

        commit.send(null);

        //解析从服务器端返回的 json 字符串,解析为一个 JavaScript 对象。

        response = json_parse(commit.responseText, null);  

        var sum=response.result;

        //获取数据集中该字段的平均值。

        commit.open("GET",encodeURI(baseuri+"/AVERAGE.json"),false,"","");

        commit.setRequestHeader("Content-Type", "application/x-www-form-urlencoded; charset=UTF-8");

        commit.send(null);

        //解析从服务器端返回的 json 字符串,解析为一个 JavaScript 对象。

        response = json_parse(commit.responseText, null);  

        var average=response.result;

        var str="1994年,全世界人口共有"+sum+"人。其中,最多的国家有"+max+"人,世界平均人口为"+average+"人。";

        //获取用作显示的 Div 容器。

        var container = document.getElementById('container');

        container.innerHTML+='<p>'+str+'</p>';

}

统计结果为: