ST_GeoHash — 返回几何图形的 GeoHash 表示。
text ST_GeoHash(
geometry geom, integer maxchars=full_precision_of_point)
;
计算几何图形的 GeoHash 表示。GeoHash 将地理点编码为文本形式,该文本形式可根据前缀进行排序和搜索。较短的 GeoHash 是对点的精度较低的表示。可以将其视为包含该点的框。
具有非零范围的非点几何值也可以映射到 GeoHash 代码。代码的精度取决于几何图形的地理范围。
如果未指定 maxchars
,则返回的 GeoHash 代码是包含输入几何图形的最小单元格的代码。点返回具有 20 个字符精度的 GeoHash(足以容纳输入的完整双精度)。其他几何类型可能会返回精度较低的 GeoHash,具体取决于几何图形的范围。较大的几何图形以较低的精度表示,较小的几何图形以较高的精度表示。由 GeoHash 代码确定的框始终包含输入要素。
如果指定了 maxchars
,则返回的 GeoHash 代码最多具有该数量的字符。它映射到输入几何图形的(可能)精度较低的表示。对于非点,计算的起点是几何图形边界框的中心。
可用性:1.4.0
ST_GeoHash 要求输入几何图形位于地理(经度/纬度)坐标中。 |
此方法支持圆形字符串和曲线。
SELECT ST_GeoHash( ST_Point(-126,48) ); st_geohash ---------------------- c0w3hf1s70w3hf1s70w3 SELECT ST_GeoHash( ST_Point(-126,48), 5); st_geohash ------------ c0w3h -- This line contains the point, so the GeoHash is a prefix of the point code SELECT ST_GeoHash('LINESTRING(-126 48, -126.1 48.1)'::geometry); st_geohash ------------ c0w3