如何优化包含地理列的sql表

我们已将地理数据存储在“位置”表中,并根据此列我们搜索给定输入的最近位置.以下查询用于获取25英里内最近的位置,此查询需要4秒以上才能检索4000条记录.我们甚至在位置字段上创建了空间索引.

DECLARE @Distance INT

SET @Distance =25

DECLARE @h sys.GEOGRAPHY

SET @h =CONVERT(sys.GEOGRAPHY, 0xE6100000010C92B06F27119D4140111AC1C6F53554C0)

SELECT CenterLocationId,
       [Location].Stdistance(@h) * Cast(0.000621371 AS FLOAT(53)) AS Distance
FROM   [dbo].[CenterLocation]
WHERE  [Location].Stdistance(@h) * Cast(0.000621371 AS FLOAT(53)) <= @Distance
       AND IsDeleted = 0
ORDER  BY [Location].Stdistance(@h) * Cast(0.000621371 AS FLOAT(53)) 

任何人都可以建议如何在SQL Server 2014中提高此查询性能?

最佳答案 有两件事,不能保证解决问题,但肯定有帮助.他们都有关系:

SELECT CenterLocationId,
       [Location].Stdistance(@h) * Cast(0.000621371 AS FLOAT(53)) AS Distance
FROM   [dbo].[CenterLocation]
WHERE  [Location].Stdistance(@h) <= @Distance / Cast(0.000621371 AS FLOAT(53))
       AND IsDeleted = 0
ORDER  BY [Location].Stdistance(@h)

也就是说,更喜欢不在WHERE子句中对依赖于列值的表达式执行数学运算 – 您强制服务器为每一行执行该数学运算并破坏使用索引的任何可能性.

此外,类似地,在ORDER BY子句中执行乘法是没有意义的,因为乘法(乘以正数)不会改变排序.

点赞