SQL Spatial Data从特定区域获取数据

时间:2012-01-19 16:01:57

标签: sql geometry geospatial

我有一个包含文本和地理列的数据库。文本是关键字的CSV,地理位置是地图上的点。

我想在特定地理区域查询前X个重复关键字的数量,并按照从最常见到最不频繁的顺序返回它们。我不知道这是否可能或从哪里开始。任何指针都会很棒!

我正在运行SQL Server 2012。

1 个答案:

答案 0 :(得分:1)

是的,这是可能的。 SQL Server(2008及更高版本)确实有两种空间类型,几何和地理。

您的数据模型可能包含两个表,一个包含几何图形,另一个包含每个区域的术语/关键字。

例如:

create table a(id int, geo geometry);
create table b(a_id int, term nvarchar(50));

-- geometry with id 1
insert into a values(1, geometry::STGeomFromText('polygon((0 0,0 4,4 4,4 0,0 0))', 0));

-- keywords for geometry with id 1
insert into b values(1, 'term 1');
insert into b values(1, 'term 2');
insert into b values(1, 'term 2'); -- twice this term, on purpose

-- geometry with id 2
insert into a values(2, geometry::STGeomFromText('polygon((10 0,10 4,14 4,14 0,10 0))', 0));

-- keywords for geometry with id 2
insert into b values(2, 'term 3');
insert into b values(2, 'term 4');
insert into b values(2, 'term 1'); -- shared between 1 and 2

然后创建一个空间查询,例如:

select a.id,b.term,COUNT(1) as frequency from a 
join b on a.id=b.a_id
where a.geo.STIntersects(geometry::STGeomFromText('polygon((2 2,2 12,12 12,12 2,2  2))', 0)) = 1
group by a.id,b.term
order by frequency desc

这将导致:

1   'term 2'    2
2   'term 3'    1
2   'term 4'    1
1   'term 1'    1
2   'term 1'    1

这就是要求的。