如何在自定义API中使用JavaScript循环Azure Mobile Service Table

时间:2015-04-22 06:03:56

标签: javascript azure-mobile-services

我想访问Azure Mobile Service Custom API中表中的所有行,提取特定列的值并对它们执行某些操作。我如何在JavaScript中以语法形式完成它?

到目前为止,我所做的是:

exports.post = function(request, response) {    
var tables = request.service.tables;

var eventIdString=request.body.EventId;
var LongClientString = request.body.Longitude;
var LatClientString = request.body.Latitude;
var eventId = parseFloat(eventIdString);
var longClient = parseFloat(LongClientString);
var latClient = parseFloat(LatClientString);

var mssql = request.service.mssql;
var sql = "SELECT * FROM User";

var str="";

mssql.query(sql, {
    success: function(results) {
        for(var i=0; i<results.length; i++)
        {
            var longServerString = results[i].longitude;
            var latServerString = results[i].latitude;
            var longServer = parseFloat(longServerString);
            var latServer = parseFloat(latServerString);

            var distance = getDistanceInKm(latClient, longClient, latServer, longServer);

            if(distance<20)
            {
                str=str+results[i].name+",";
            } 
        }
    }});    

response.send(statusCodes.OK, { message : str }); 

//calculating distace
function getDistanceInKm(lat1,lon1,lat2,lon2) {
var R = 6371; // Radius of the earth in km
var dLat = deg2rad(lat2-lat1);  // deg2rad below
var dLon = deg2rad(lon2-lon1); 
var a = 
Math.sin(dLat/2) * Math.sin(dLat/2) +
Math.cos(deg2rad(lat1)) * Math.cos(deg2rad(lat2)) * 
Math.sin(dLon/2) * Math.sin(dLon/2); 
var c = 2 * Math.atan2(Math.sqrt(a), Math.sqrt(1-a)); 
var d = R * c; // Distance in km
return d;
}

function deg2rad(deg) {
return deg * (Math.PI/180)
} };

但我在'str'中什么都没得到。我做错了什么?

1 个答案:

答案 0 :(得分:1)

代码中的问题是,在使用mssql.query变量之前,您不是在等待str调用的结果。与node.js-land中的几乎所有内容一样,query是一个异步操作,因此当它返回时,尚未调用成功回调。

尝试将response.send调用移至回调内部,您应该会看到一些结果。

mssql.query(sql, {
    success: function (results) {
        for(var i = 0; i < results.length; i++)
        {
            var longServerString = results[i].longitude;
            var latServerString = results[i].latitude;
            var longServer = parseFloat(longServerString);
            var latServer = parseFloat(latServerString);

            var distance = getDistanceInKm(latClient, longClient, latServer, longServer);

            if(distance < 20)
            {
                str = str + results[i].name + ",";
            }
        }
        response.send(statusCodes.OK, { message : str });
    }
});