SQL 查询支持设置其他查询条件,如:属性过滤条件(attributeFilter)、分组条件(groupBy)、查询 id 数组(ids)、关联查询项数组(joinItems)、关联外部表(linkItems)、SQL 查询排序的字段(orderBy)等信息。现以关联外部表(LinkItem)为例,构建一个简单 SQL 查询:获取世界地图的 Countries@World 图层 与 Capitals@World 图层中 Capital 字段值相等的数据记录。
对于该 SQL 查询,主要传递参数:queryMode 和 queryParameters。queryMode 说明查询模式(这里是 SqlQuery),queryParameters 是查询的参数,构建查询代码如下:
//关联外表 SQL 查询
function SQLQueryByLinkItem()
{
var commit=getcommit();
var uri="http://localhost:8090/iserver/services/map-world/rest/maps/World Map/queryResults.rjson";
//设置请求体参数
var entry={};
entry.queryMode="SqlQuery";
entry.queryParameters={
"startRecord": 0,
"queryParams": [{
"name": "Capitals@world",
"linkItems": [{
"datasourceConnectionInfo": {
"engineType": "UDB",
"readOnly": false,
"connect": true,
"openLinkTable": false,
"alias": "World",
"exclusive": false
},
"name": null,
"foreignKeys": ["Capital"],
"primaryKeys": ["Capital"],
"linkFilter": "Capital = Capital",
"foreignTable": "Countries"
}]
}],
"expectCount": 100000,
"queryOption": "ATTRIBUTEANDGEOMETRY"
};
commit.open("POST",encodeURI(uri),false,"","");
commit.setRequestHeader("Content-Type", "application/x-www-form-urlencoded; charset=UTF-8");
//alert(toJSON(entry));
commit.send(toJSON(entry));
//解析从服务器端返回的 json 字符串,解析为一个 JavaScript 对象。
var response = json_parse(commit.responseText, null);
//获取用作显示的 Div 容器。
var container = document.getElementById('container');
container.innerHTML="";
//判断查询是否成功
if(!response.succeed)
{
//查询失败
container.innerHTML+="<p>查询失败</p>";
container.innerHTML+="<p>错误码:"+response.error.code+"</p><p>错误原因:"+response.error.errorMsg+"</p>";
}else
{
//查询成功
container.innerHTML+="<p>查询成功</p>";
container.innerHTML+="<p>查询结果(queryResult)资源的 URI 为:"+response.newResourceLocation+"</p>";
}
}
其中,linkItems 用于指定关联外部表的参数,详见LinkItem,其他参数可参考SQL 查询。
执行查询,得到 URI 地址类似 http://localhost:8090/iserver/services/map-world/rest/maps/World Map/queryResults/3jx2ilcv_c81111e25a7f404ea36b2c8690756453.rjson 的 queryResult 资源,该 queryResult 资源包含了符合条件的记录的相关信息。
queryResult 资源的进一步解析请参见 queryResult 的解析。