21. 几何构造练习¶
以下是我们见过的一些函数的提醒。提示:它们应该对练习很有用!
sum(expression) 聚合以返回一组记录的总和
ST_Area(geometry) 返回几何图形的面积
ST_Centroid(geometry) 返回
geometry
的质心ST_Transform(geometry, srid) 将
geometries
转换为不同的空间参考系统ST_Buffer(geometry, radius) 返回扩展的
geometry
形状ST_Contains(geometry1, geometry2) 如果 geometry1 包含 geometry2,则返回 true
ST_Union(geometry[]) 返回组中所有几何图形的聚合并集
ST_GeometryType(geometry) 返回几何图形的类型
ST_NumGeometries(geometry) 返回集合中几何图形的数量,或简单几何图形返回 1
ST_Intersection(geometry, geometry) 返回两个输入几何图形共享的公共区域
记住我们可用的表
nyc_census_blocks
name, popn_total, boroname, geom
nyc_streets
name, type, geom
nyc_subway_stations
name, geom
nyc_neighborhoods
name, boroname, geom
21.1. 练习¶
有多少个人口普查区块不包含它们自己的质心?
SELECT Count(*) FROM nyc_census_blocks WHERE NOT ST_Contains( geom, ST_Centroid(geom) );
481
将所有人口普查区块合并为一个输出。它是什么类型的几何图形?它有多少个部分?
CREATE TABLE nyc_census_blocks_merge AS SELECT ST_Union(geom) AS geom FROM nyc_census_blocks; SELECT ST_GeometryType(geom) FROM nyc_census_blocks_merge;
ST_MultiPolygon
SELECT ST_NumGeometries(geom) FROM nyc_census_blocks_merge;
63
原点周围一个单位缓冲区的面积是多少?它与你期望的有多大不同?为什么?
SELECT ST_Area(ST_Buffer('POINT(0 0)', 1));
3.121445152258052
注意
一个单位圆(半径为 1 的圆)应该有 pi 的面积,3.1415926... 差异是由于缓冲区的边缘的线性描绘造成的。缓冲区具有有限数量的边缘。增加缓冲区中的边缘数量将使该值更接近 pi,但由于线性化,它将始终较小。
布鲁克林的“公园坡”和“卡罗尔花园”社区即将开战!构造一个多边形,描绘社区之间边界上 100 米宽的非军事区。非军事区的面积是多少?
CREATE TABLE brooklyn_dmz AS SELECT ST_Intersection( ST_Buffer(ps.geom, 50), ST_Buffer(cg.geom, 50)) AS geom FROM nyc_neighborhoods ps, nyc_neighborhoods cg WHERE ps.name = 'Park Slope' AND cg.name = 'Carroll Gardens'; SELECT ST_Area(geom) FROM brooklyn_dmz;
注意
很容易缓冲感兴趣的两个社区,但要获得交集,需要对表进行自联接,创建一个只包含“公园坡”记录的关系 (
ps
) 和另一个只包含“卡罗尔花园”记录的关系 (cg
)。 请注意,交集的面积以平方米为单位,因为我们仍然在 UTM 18 (EPSG:26918) 中工作。180990.964207547