在SQL中查找最近邻居的id

时间:2015-06-03 14:37:51

标签: sql-server geolocation greatest-n-per-group nearest-neighbor

我有一张桌子,#geo,地理位置有点。

Id        geolocation
9201      0xE6100000010CE33995EB71164CC054791243B87441C0
9202      0xE6100000010C56B77A4E7A1B4CC0D15790662C6E41C0

我计算了每个数据点到最近邻居的距离。 我24个月有1000点积分。现在我用一个月的前19个点复制我的代码

create table #Geo
(
    id               int
    ,geolocation     geography
)

INSERT INTO #geo (id, geolocation)
Select 224,0xE6100000010CE33995EB71164CC054791243B87441C0 UNION ALL
Select 225,0xE6100000010CE7D4BE4EA4184CC0CC947B26A07341C0 UNION ALL
Select 226,0xE6100000010C97A8DE1AD81A4CC0139B8F6B436941C0 UNION ALL
Select 227,0xE6100000010C2EAC1BEF8E164CC0DF80E03B7B7341C0 UNION ALL
Select 228,0xE6100000010CE49BD09887174CC00CADD206F57341C0 UNION ALL
Select 229,0xE6100000010C2B009DB436184CC0FD8E1B5D297441C0 UNION ALL
Select 230,0xE6100000010CFBAC32535A154CC054C72AA5677241C0 UNION ALL
Select 231,0xE6100000010CAE9E93DE37024CC0A167B3EA736141C0 UNION ALL
Select 232,0xE6100000010C70B1A206D3EC4BC0B4024356B76241C0 UNION ALL
Select 233,0xE6100000010CEA78CC40651C4CC097C5C4E6E30A41C0 UNION ALL
Select 234,0xE6100000010CDBFD2AC0770F4CC09E996038D76E41C0 UNION ALL
Select 235,0xE6100000010CA1CB487B8B794BC0C84C9AED277041C0 UNION ALL
Select 236,0xE6100000010CC0076D4108154CC07DD8A069E86E41C0 UNION ALL
Select 237,0xE6100000010C103B53E8BC1E4CC062670A9DD7E03FC0 UNION ALL
Select 238,0xE6100000010CDD94A1130A004CC0ACA6B697DEBB3FC0 UNION ALL
Select 239,0xE6100000010CAB750381252B4BC0F1DDFF2A343D41C0 UNION ALL
Select 240,0xE6100000010CD925AAB706CA4BC045813E91275D40C0 UNION ALL
Select 241,0xE6100000010CD1EB4FE2F3134BC014DA6ABD7C5441C0 UNION ALL
Select 242,0xE6100000010CB32A5F238B144CC0C3E37020037441C0 
--select * from  #Geo


select com.id 
, min( com.GeoLocation.STDistance(com2.GeoLocation)) dist
from #geo com
join    #geo com2   on com.id<>com2.id      
group by com.id 

id  dist
224 608.936575787757
225 454.190509008084
... ...

现在我需要得到最近邻居的id:

id  dist               Id_with_minimum_distance
224 608.936575787757     ?
225 454.190509008084     ?

感谢您的帮助。

1 个答案:

答案 0 :(得分:1)

您可以使用包含n的子查询来过滤除最近的row_number行以外的所有内容:

com2

Example at SQL Fiddle.