<div dir="ltr"><div dir="ltr"><div>If you are running a query on the Geography, you should create the index on Geography, using something like this: Create Index g_geog_idx on mySchema.myTable using GIST(geom::geography);</div><div><br></div><div>Using this increased the speed of my query 1000 times.</div><div><br></div><div>Source: <br></div><div><a href="https://twitter.com/postgis/status/675001071505383424">https://twitter.com/postgis/status/675001071505383424</a></div><div><br></div><div><br></div><div><div><div dir="ltr" class="gmail_signature"><div dir="ltr"><div><div dir="ltr"><font size="2" color="#999999">Regards,</font><div><font size="2" color="#444444">Devdatta</font></div></div></div></div></div></div><br></div></div></div><br><div class="gmail_quote"><div dir="ltr">On Tue, Jan 15, 2019 at 4:07 PM David M. Kaplan <<a href="mailto:david.kaplan@ird.fr">david.kaplan@ird.fr</a>> wrote:<br></div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex">
<div bgcolor="#FFFFFF">
Hi,<br>
<br>
For a while it has not been clear in my head if and when GIST
indexes are used when doing geography based calculations. If the
data is stored in a table with a geometry column that has a GIST
index on it, will that index be used if one does something like
ST_DWithin(a.geom::geography,b.geom,1000)? If not, then if the data
was stored in geography format instead of geometry, would this make
the index more useful?<br>
<br>
To give a specific context, I have a table of point geometries with
SRID 4326 and a GIST index, and I want to find the number of points
in that table that are within a certain distance of each other point
in that table, but I am not sure what is the most efficient way to
do so. To do this, I have a query of the form:<br>
<br>
<pre>SELECT a.gid, a.geom, count(*) AS num_points</pre>
<pre>FROM mytable a</pre>
<pre>JOIN mytable b </pre>
<pre> ON a.gid<>b.gid
AND ST_DWithin(a.geom::geography,b.geom,1000,FALSE)</pre>
<pre>GROUP BY a.gid,a.geom</pre>
<pre>;</pre>
<br>
This is quite slow, so I presume the GIST index is not being used
(and EXPLAIN didn't show anything that made it clear that it was
being used though bounding box comparisons are included in the join
filter). Also adding a lonlat bounding box comparison does speed the
calculation up significantly:<br>
<br>
<pre>SELECT a.gid, a.geom, count(*) AS num_points</pre>
<pre>FROM mytable a</pre>
<pre>JOIN mytable b </pre>
<pre> ON a.gid<>b.gid
AND a.geom <#> b.geom < 0.02 -- in region where 0.02 degrees is > 1000 m
AND ST_DWithin(a.geom::geography,b.geom,1000,FALSE)</pre>
<pre>GROUP BY a.gid,a.geom</pre>
<pre>;</pre>
<br>
Is this the best approach or am I missing something? Would using a
LATERAL join improve things?<br>
<br>
Thanks,<br>
David<br>
<br>
<br>
<pre class="gmail-m_814158657985940150moz-signature" cols="72">--
**********************************
David M. Kaplan
Charge de Recherche 1
Institut de Recherche pour le Developpement (IRD)
UMR MARBEC (IRD/Ifremer/CNRS/UMII)
av. Jean Monnet
CS 30171
34203 Sete cedex
France
Email: <a class="gmail-m_814158657985940150moz-txt-link-abbreviated" href="mailto:david.kaplan@ird.fr" target="_blank">david.kaplan@ird.fr</a>
Phone: +33 (0)4 99 57 32 25
Fax: +33 (0)4 99 57 32 95
<a class="gmail-m_814158657985940150moz-txt-link-freetext" href="http://www.umr-marbec.fr/kaplan-david.html" target="_blank">http://www.umr-marbec.fr/kaplan-david.html</a>
<a class="gmail-m_814158657985940150moz-txt-link-freetext" href="http://www.davidmkaplan.fr/" target="_blank">http://www.davidmkaplan.fr/</a>
**********************************
</pre>
</div>
_______________________________________________<br>
postgis-users mailing list<br>
<a href="mailto:postgis-users@lists.osgeo.org" target="_blank">postgis-users@lists.osgeo.org</a><br>
<a href="https://lists.osgeo.org/mailman/listinfo/postgis-users" rel="noreferrer" target="_blank">https://lists.osgeo.org/mailman/listinfo/postgis-users</a></blockquote></div>