[postgis-tickets] r16706 - Clarify ST_DWithin usage when table stores a point and a radius.

Darafei komzpa at gmail.com
Tue Aug 28 12:45:03 PDT 2018


Author: komzpa
Date: 2018-08-28 00:45:03 -0700 (Tue, 28 Aug 2018)
New Revision: 16706

Modified:
   trunk/NEWS
   trunk/doc/reference_measure.xml
Log:
Clarify ST_DWithin usage when table stores a point and a radius.

Added after IRC discussion.
Thanks github user Boscop for questions and review.

Closes #4162
Closes https://github.com/postgis/postgis/pull/289



Modified: trunk/NEWS
===================================================================
--- trunk/NEWS	2018-08-28 07:25:28 UTC (rev 16705)
+++ trunk/NEWS	2018-08-28 07:45:03 UTC (rev 16706)
@@ -3,8 +3,9 @@
 * Enhancements *
   - #4153, ST_Segmentize now splits segments proportionally (Darafei
     Praliaskouski).
+  - #4162, ST_DWithin documentation examples for storing geometry and
+    radius in table (Darafei Praliaskouski, github user Boscop).
 
-
 PostGIS 2.5.0rc1
 2018/08/19
 New since PostGIS 2.5.0beta2

Modified: trunk/doc/reference_measure.xml
===================================================================
--- trunk/doc/reference_measure.xml	2018-08-28 07:25:28 UTC (rev 16705)
+++ trunk/doc/reference_measure.xml	2018-08-28 07:45:03 UTC (rev 16706)
@@ -3059,7 +3059,7 @@
 		<refname>ST_DWithin</refname>
 
 		<refpurpose>Returns true if the geometries are within the specified
-		distance of one another. For geometry units are in those of spatial reference and For geography units are in meters and measurement is
+		distance of one another. For geometry units are in those of spatial reference and for geography units are in meters and measurement is
 		defaulted to use_spheroid=true (measure around spheroid), for faster check, use_spheroid=false to measure along sphere.</refpurpose>
 	  </refnamediv>
 
@@ -3111,14 +3111,16 @@
 
 		<para>Returns true if the geometries are within the specified distance
 		of one another.</para>
-		<para>For Geometries: The distance is specified in units defined by the
+
+		<para>For <type>geometry</type>: The distance is specified in units defined by the
 		spatial reference system of the geometries.  For this function to make
 		sense, the source geometries must both be of the same coordinate projection,
 		having the same SRID.</para>
 
-		<para>For geography units are in meters and measurement is
-		defaulted to use_spheroid=true, for faster check, use_spheroid=false to measure along sphere.
+		<para>For <type>geography</type> units are in meters and measurement is
+		defaulted to <varname>use_spheroid</varname>=true, for faster check, <varname>use_spheroid</varname>=false to measure along sphere.
 		</para>
+
 		<note>
 		  <para>This function call will automatically include a bounding box
 		  comparison that will make use of any indexes that are available on
@@ -3143,23 +3145,40 @@
 	  <refsection>
 		<title>Examples</title>
 		  <programlisting>
---Find the nearest hospital to each school
---that is within 3000 units of the school.
--- We do an ST_DWithin search to utilize indexes to limit our search list
--- that the non-indexable ST_Distance needs to process
---If the units of the spatial reference is meters then units would be meters
-SELECT DISTINCT ON (s.gid) s.gid, s.school_name, s.the_geom, h.hospital_name
+-- Find the nearest hospital to each school
+-- that is within 3000 units of the school.
+--  We do an ST_DWithin search to utilize indexes to limit our search list
+--  that the non-indexable ST_Distance needs to process
+-- If the units of the spatial reference is meters then units would be meters
+SELECT DISTINCT ON (s.gid) s.gid, s.school_name, s.geom, h.hospital_name
 	FROM schools s
-		LEFT JOIN hospitals h ON ST_DWithin(s.the_geom, h.the_geom, 3000)
-	ORDER BY s.gid, ST_Distance(s.the_geom, h.the_geom);
+		LEFT JOIN hospitals h ON ST_DWithin(s.the_geom, h.geom, 3000)
+	ORDER BY s.gid, ST_Distance(s.geom, h.geom);
 
---The schools with no close hospitals
---Find all schools with no hospital within 3000 units
---away from the school.  Units is in units of spatial ref (e.g. meters, feet, degrees)
+-- The schools with no close hospitals
+-- Find all schools with no hospital within 3000 units
+-- away from the school.  Units is in units of spatial ref (e.g. meters, feet, degrees)
 SELECT s.gid, s.school_name
 	FROM schools s
-		LEFT JOIN hospitals h ON ST_DWithin(s.the_geom, h.the_geom, 3000)
+		LEFT JOIN hospitals h ON ST_DWithin(s.geom, h.geom, 3000)
 	WHERE h.gid IS NULL;
+
+-- Find broadcasting towers that receiver with limited range can receive.
+-- Data is geometry in Spherical Mercator (SRID=3857), ranges are approximate.
+
+-- Create geometry index that will check proximity limit of user to tower
+CREATE INDEX ON broadcasting_towers using gist (geom);
+
+-- Create geometry index that will check proximity limit of tower to user
+CREATE INDEX ON broadcasting_towers using gist (ST_Expand(geom, sending_range));
+
+-- Query towers that 4-kilometer receiver in Minsk Hackerspace can get
+-- Note: two conditions, because shorter LEAST(b.sending_range, 4000) will not use index.
+SELECT b.tower_id, b.geom
+  FROM broadcasting_towers b
+  WHERE ST_DWithin(b.geom, 'SRID=3857;POINT(3072163.4 7159374.1)', 4000)
+	  AND ST_DWithin(b.geom, 'SRID=3857;POINT(3072163.4 7159374.1)', b.sending_range);
+
 			  </programlisting>
 	  </refsection>
 
@@ -3166,7 +3185,7 @@
 	  <refsection>
 		<title>See Also</title>
 
-		<para><xref linkend="ST_Distance"/>, <xref linkend="ST_Expand"/></para>
+		<para><xref linkend="ST_Distance"/>, <xref linkend="ST_Expand"/>, <xref linkend="ST_3DDWithin"/></para>
 	  </refsection>
 	</refentry>
 



More information about the postgis-tickets mailing list