gpt4 book ai didi

javascript - 如何在自定义 API 中使用 JavaScript 循环访问 Azure 移动服务表

转载 作者:行者123 更新时间:2023-12-03 10:17:44 25 4
gpt4 key购买 nike

我想访问 Azure 移动服务自定义 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”中什么也没得到。我做错了什么??

最佳答案

代码中的问题是,在使用 str 变量之前,您没有等待 mssql.query 调用的结果。与 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 });
}
});

关于javascript - 如何在自定义 API 中使用 JavaScript 循环访问 Azure 移动服务表,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29789018/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com