won*_*ook 12
我们用它来做成千上万的点.如果您在SQL中执行此操作以在"纬度"和"经度"列上创建索引,则这一点非常重要.我们尝试在SQL 2008中使用空间索引执行此操作,但我们确实没有看到我们预期的性能提升.虽然如果要在距离ZIP一定距离内进行计算,您需要考虑是否要使用ZIP质心或邮政编码的多边形表示.
Haversine forumla是一个很好的起点.
我们没有在运行中计算距离的性能问题,我们提前计算了一些应用程序,我们提前知道这些点并且将有数百万条记录.
SELECT
[DistanceRadius]=
69.09 *
DEGREES(
ACOS(
SIN( RADIANS(latitude) )*SIN( RADIANS(@ziplat) )
+
COS( RADIANS(latitude) )*COS( RADIANS(@ziplat) )
*
COS( RADIANS(longitude - (@ziplon)) )
)
)
,*
FROM
table
) sub
WHERE
sub.DistanceRadius < @radius
Run Code Online (Sandbox Code Playgroud)
如果有足够的记录速度,那么这是一种提前索引它们的方法.
定义一侧约20英里的垃圾箱网格.将箱号存储在每个商店的记录中.在搜索时,计算与搜索点相距20英里半径的所有箱的数量.然后检索任何这些箱中的所有商店,并像以前一样继续.
| 归档时间: |
|
| 查看次数: |
8569 次 |
| 最近记录: |