开发者

Ms SQL geography.STDistance returns wrong distance

开发者 https://www.devze.com 2023-03-16 02:48 出处:网络
I\'m trying to query any locations within a specified distance from another location. The query is not the problem, but the distance returned by geography.STDistance is.

I'm trying to query any locations within a specified distance from another location. The query is not the problem, but the distance returned by geography.STDistance is.

It seems STDistance makes fairly accurate calculations on locations close to the equator, but I need this to work with locations in the nordic countries. Norway, Sweden, Finland and so on...

According to my calculations, made on locations in northern Sweden, the distance is wrong by a factor of around 2.38?! Expected result is 1070 meters and returned distance is 2537,28850694302 meters

My query looks like this:

DECLARE @g geography = geography::STGeomFromText('POINT(65.580254 22.179428)', 4326)

SELECT name, [pos].STSrid as srdi, 开发者_JAVA百科[pos].STDistance(@g) as d
  FROM [GPSCHAT].[dbo].[USERS]

and the "other location" has coordinates (65,578541 22,202286) (stored with SRID 4326)

I'm guessing this has to do with the distance from the equator (close to the polar circle), but there has to be a way to calculate this more accurately based on the Latitude or am i wrong?


It looks like you're creating your point using 'X, Y'.
When creating a point from text, use 'Y, X' instead.

Check out this MSDN Article for some more info.


Why don't you make use of another spatial reference identifier which fits better the earth curvature around your position. SRID 4326 might not been measured as accurate as other local referential systems

0

精彩评论

暂无评论...
验证码 换一张
取 消