好的,我已经搜索了SO和谷歌,但还没有真正找到明确的答案,所以把它扔到那里为SO社区.
基本上我有一个针对特定兴趣点的经度和纬度表,SQL查询将知道你当前所在的位置(这将是表格中的一个,作为参数传入),因此它需要计算并将最接近纬度和经度的一行返回到传入的一行.
我要求这一切都在MSsql(2012 /存储过程)而不是在调用应用程序(这是.NET)中完成,因为我听说sql处理此类查询通常比.NET更快?
编辑:
我找到了STDistance函数,它给出了位置之间的里程数,例如:
DECLARE @NWI geography,@EDI geography SET @NWI = geography::Point(52.675833,1.282778,4326) SET @EDI = geography::Point(55.95,-3.3725,4326) SELECT @NWI.STDistance(@EDI) / 1000
但是我不想迭代遍历表中的所有纬度/经度,因为这对于性能来说肯定会很糟糕吗?
我也试过转换下面的一个注释链接中指出的一个例子(这是MysqL而不是MSsql)但是我收到一个错误,代码如下:
DECLARE @orig_lat decimal(6,2),@orig_long decimal(6,@bounding_distance int set @orig_lat=52.056736; set @orig_long=1.14822; set @bounding_distance=1; SELECT *,((ACOS(SIN(@orig_lat * PI() / 180) * SIN('lat' * PI() / 180) + COS(@orig_lat * PI() / 180) * COS('lat' * PI() / 180) * COS((@orig_long - 'lon') * PI() / 180)) * 180 / PI()) * 60 * 1.1515) AS 'distance' FROM [DB1].[dbo].[LatLons] WHERE ( 'lat' BETWEEN (@orig_lat - @bounding_distance) AND (@orig_lat + @bounding_distance) AND 'lon' BETWEEN (@orig_long - @bounding_distance) AND (@orig_long + @bounding_distance) ) ORDER BY 'distance' ASC
收到的错误是:
Msg 8114,Level 16,State 5,Line 6 Error converting data type varchar
to numeric.