service/datastore/postgis/PostgisCustomQueryService.js Source
import { Zondy } from '../../common/Base';
import { DataStoreService } from '../ServiceBase';

/**
 * @author 创新中心-潘卓然
 * @class module:PostGIS.PostgisCustomQueryService
 * @param {PostgisQueryParameter} option 查询条件
 * @param {String} [option.path] 库名称
 * @param {String} [option.queryBody] 查询sql语句,如:select * from hunan01.dltb2005 where 地类编码 == 1011 limit 1
 */
export class PostgisCustomQueryService extends DataStoreService {
    constructor(option) {
        super(option);

        /**
         * @member module:PostGIS.PostgisCustomQueryService.prototype.serviceUrl
         * @description 服务地址
         */
        this.serviceUrl = '/datastore/rest/dataset/pg/executequery/';
        /**
         * @member module:PostGIS.PostgisCustomQueryService.prototype.path
         * @description 库名称
         */
        this.path = option.path;
        /**
         * @member module:PostGIS.PostgisCustomQueryService.prototype.queryBody
         * @description 查询sql语句,如:
         * select * from hunan01.dltb2005 where 地类编码 == 1011 limit 1
         */
        this.queryBody = option.queryBody;

        this.fixOption(option);
    }

    /**
     * @private 修正get/post需要的真正参数
     */
    fixOption(option) {
        this.option = {
            queryBody: option.queryBody
        };
    }

    /**
     * @description 查询函数,向服务器发送请求,返回地名地址格式数据
     * @function module:PostGIS.PostgisCustomQueryService.prototype.query
     * @param  {Function} onSuccess 查询成功回调函数。
     * @param {Function} onError 查询失败回调函数。
     */
    query(onSuccess, onError) {
        let { serviceUrl, path, option } = this;
        serviceUrl += path;
        let url = this.getFullUrl(serviceUrl, option);
        this.get(url, onSuccess, onError);
    }
}

export default PostgisCustomQueryService;
Zondy.DataStore.PostGIS.PostgisCustomQueryService = PostgisCustomQueryService;