<#> — 返回A和B边界框之间的2D距离。
double precision
<#>
(
geometry
A
, geometry
B
)
;
这个
<#>
运算符返回两个浮点边界框之间的距离,可能从空间索引中读取它们(需要PostgreSQL 9.1+)。对做最近的邻居很有用
近似值
距离排序。
![]() |
|
此操作数将使用几何图形上可用的任何索引。它与其他使用空间索引的运算符的不同之处在于,仅当运算符位于ORDER BY子句中时才使用空间索引。 |
![]() |
|
索引仅在其中一个几何为常量时才起作用,例如ORDER BY(ST_GeomFromText(‘point(1 2)’)) <#> Geom)而不是g1.geom <#> 。 |
可用性:2.0.0--KNN仅适用于PostgreSQL 9.1+
SELECT *
FROM (
SELECT b.tlid, b.mtfcc,
b.geom <#> ST_GeomFromText('LINESTRING(746149 2948672,745954 2948576,
745787 2948499,745740 2948468,745712 2948438,
745690 2948384,745677 2948319)',2249) As b_dist,
ST_Distance(b.geom, ST_GeomFromText('LINESTRING(746149 2948672,745954 2948576,
745787 2948499,745740 2948468,745712 2948438,
745690 2948384,745677 2948319)',2249)) As act_dist
FROM bos_roads As b
ORDER BY b_dist, b.tlid
LIMIT 100) As foo
ORDER BY act_dist, tlid LIMIT 10;
tlid | mtfcc | b_dist | act_dist
-----------+-------+------------------+------------------
85732027 | S1400 | 0 | 0
85732029 | S1400 | 0 | 0
85732031 | S1400 | 0 | 0
85734335 | S1400 | 0 | 0
85736037 | S1400 | 0 | 0
624683742 | S1400 | 0 | 128.528874268666
85719343 | S1400 | 260.839270432962 | 260.839270432962
85741826 | S1400 | 164.759294123275 | 260.839270432962
85732032 | S1400 | 277.75 | 311.830282365264
85735592 | S1400 | 222.25 | 311.830282365264
(10 rows)