<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
<head>
<meta content="text/html;charset=UTF-8" http-equiv="Content-Type">
</head>
<body bgcolor="#ffffff" text="#000000">
Whit postGIS you always have the overhead of making a connection to the
database, authentication whilst with a shapefile it is just disk IO
access.<br>
<br>
For my own business case(s): being able to have users edit
simultanously, restrict user access to certain tables, data validation
with triggers, restricted user access and so on is a major PLUS to
select postGIS above shape. Our customers have no problem with a minute
wait time to get the data in their openJUMP or quantumGIS. In openJUMP
they work "cached local" giving them all the functions they need and
then when they decide to upload the dataset, validation takes place.<br>
<br>
For view only; we have a mapserver implementation that other users can
access as a WMS layer from their GIS or Google Earth.<br>
<br>
So it is all a matter of favour and the way you want to use it.<br>
<br>
My general criteria?<br>
<br>
If it needs to be multi-user, many changes to the dataset; postGIS<br>
If it is static, single user, large amount of data, little changes;
shape<br>
<br>
kind regards,<br>
<br>
<br>
<br>
<br>
Johannes Sommer schreef:
<blockquote cite="mid:47330C40.8060807@gmx.de" type="cite">Hi
everybody!
<br>
<br>
I made a little performance test: shape vs. postgis.
<br>
I always thought that a select query in a postgresql database with
postgis extension
<br>
is much faster than a comparable query inside a Desktop GIS that has
loaded shape-files.
<br>
So I compared various queries with shape-files (different sizes and
geometry types) and relations in a postgis database.
<br>
The shapes I queried in the Desktop GISs have been converted to a
postgis-layer.
<br>
I used Kosmo, Openjump and ArcMap as Desktop GISs.
<br>
<br>
However the result is the following: PostGIS is always slower than the
Desktop GISs.
<br>
<br>
I know Openjump is using Quadtrees to index a shape-file, about Kosmo
and ArcMap I have no idea, but I think they use an index too.
<br>
And in postgis I build an GiST- index on the queried relations and did
a VACUUM ANALYZE on them.
<br>
<br>
So why is a (spatial) query in a database slower, than a query of a
shape-file? Can anybody explain this to me?
<br>
Anyone with similar experiences?
<br>
Perhaps there is something wrong with the "select query" or with the
database's properties?
<br>
<br>
System: 2,8 Ghz, 1 GB RAM, S-ATA HDD, Windows XP Pro
<br>
Software: Postgresql 8.2.5 with PostGIS 1.3
<br>
OpenJUMP 1.2 D
<br>
ArcMap 9.1
<br>
<br>
Thanks for your comments.
<br>
<br>
greetings,
<br>
Johannes Sommer
<br>
<br>
*A. MULTIPOLYGONS and POINTS*
<br>
<br>
1.
<br>
<br>
*shapes: *lsg (678 MULTIPOLYGONS), 14,5 MB, bze_wze, 52 KB, (386
<br>
POINTS),
<br>
<br>
intersection
<br>
<br>
Results:
<br>
<br>
*
<br>
<br>
Openjump 1.2 D: 24 sec
<br>
<br>
*
<br>
<br>
ArcMap 9.1: 18 sec
<br>
<br>
*
<br>
<br>
Kosmo 1.1: 1:24 min
<br>
<br>
#
<br>
<br>
both are marked as „Layer in memory“: 0:59 min
<br>
<br>
1.
<br>
<br>
*postgis-layer: *lsg (678 MULTIPOLYGONS, GiST-Index on geometry),
<br>
bze_wze (386 POINTS, GiST-Index on geometry)
<br>
<br>
Result:
<br>
<br>
+
<br>
<br>
Openjump 1.2 D: 24 sec
<br>
<br>
+
<br>
<br>
Kosmo 1.1: 2:44 min
<br>
<br>
#
<br>
<br>
both are marked as „Layer in memory“: 1:00 min
<br>
<br>
+
<br>
<br>
PostGIS-SQL:
<br>
<br>
#
<br>
<br>
intersection with && (bbox): 2:45 min
<br>
<br>
SELECT intersection(a.geometry, b.geometry) AS intersection_geom,
<br>
a.gid, a.tnr, a.ist_x, a.ist_y, a.holzboden, a.eu_punkt,
<br>
b.rok_prj_nr, b.id, b.name, b.area_qm
<br>
FROM lsg b, bze_wze a
<br>
WHERE intersects(a.geometry, b.geometry); <br>
#
<br>
<br>
intersection with && (bbox): 2:24 min
<br>
<br>
SELECT intersection(a.geometry, b.geometry) AS intersection_geom,
<br>
a.*, b.rok_prj_nr, b.id, b.name, b.area_qm
<br>
FROM lsg b, bze_wze a
<br>
WHERE a.geometry && b.geometry
<br>
AND intersects(a.geometry, b.geometry);
<br>
<br>
<br>
*B. POLYGONS and POINTS*
<br>
<br>
1.
<br>
<br>
*shapes:** *ffh_gebiete (2670 POLYGONS), 12,7 MB, bze_wze, 52 KB,
<br>
(386 POINTS)
<br>
<br>
intersection
<br>
<br>
Results:
<br>
<br>
*
<br>
<br>
Openjump 1.2 D: 1 sec
<br>
<br>
*
<br>
<br>
ArcMap 9.1: 12 sec
<br>
<br>
*
<br>
<br>
Kosmo 1.1: 6 sec
<br>
<br>
o
<br>
<br>
Layer in memory: 1 sec
<br>
<br>
2.
<br>
<br>
*postgis-layer: *ffh_gebiete (2670 POLYGONS, GiST-Index on
<br>
geometry), bze_wze (386 POINTS, GiST-Index on geometry)
<br>
<br>
Results:
<br>
<br>
+
<br>
<br>
Openjump 1.2 D: 1 sec
<br>
<br>
+
<br>
<br>
Kosmo 1.1: 8 sec
<br>
<br>
#
<br>
<br>
Layer in memory: 2 sec
<br>
<br>
+
<br>
<br>
PostGIS-SQL:
<br>
<br>
# intersection without && (bbox): 35 sec
<br>
# intersection with && (bbox): 17 sec
<br>
<br>
<br>
*C. POLYGONS and POLYGONS*
<br>
<br>
1.
<br>
<br>
*shapes:** *ffh_gebiete (2670 POLYGONS) 12,7 MB, * *gk500_1 (16503
<br>
POLYGONS) 22,8 MB
<br>
<br>
intersection
<br>
<br>
Result:
<br>
<br>
*
<br>
<br>
Openjump 1.2 D: 1:58 min
<br>
<br>
*
<br>
<br>
ArcMap 9.1: 38 sec
<br>
<br>
*
<br>
<br>
Kosmo 1.1: 4:02 min
<br>
<br>
2.
<br>
<br>
*postgis-layer: *ffh_gebiete (2670 POLYGONS, GiST-Index on
<br>
geometry), gk500_1 (16503 POLYGONS, GiST-Index on geometry)
<br>
<br>
Result:
<br>
<br>
+
<br>
<br>
Openjump 1.2 D: 2:00 min
<br>
<br>
+
<br>
<br>
Kosmo 1.1: 3:59 min
<br>
<br>
+
<br>
<br>
PostGIS-SQL:
<br>
<br>
# intersection without && (bbox): 33:09
min
<br>
# intersection with && (bbox): 8:02 min
<br>
<br>
<br>
_______________________________________________
<br>
postgis-users mailing list
<br>
<a class="moz-txt-link-abbreviated" href="mailto:postgis-users@postgis.refractions.net">postgis-users@postgis.refractions.net</a>
<br>
<a class="moz-txt-link-freetext" href="http://postgis.refractions.net/mailman/listinfo/postgis-users">http://postgis.refractions.net/mailman/listinfo/postgis-users</a>
<br>
<br>
</blockquote>
<br>
<br>
<div class="moz-signature">-- <br>
<title>3DSite</title>
<meta http-equiv="Content-Type" content="text/html; ">
<style type="text/css">
<!--
body {
background-color: #FFFFFF;
margin-left: 5px;
margin-top: 5px;
margin-right: 5px;
margin-bottom: 5px;
}
body,td,th {
font-family: Arial, Helvetica, sans-serif;
font-size: 12px;
color: #333333;
}
.style4 {font-size: 9px; }
.style5 {font-size: 9px; color: #CCCCCC; }
-->
</style>
<meta content="MSHTML 6.00.2900.2912" name="GENERATOR">
<br>
<table border="0" cellpadding="0" cellspacing="0" width="400">
<tbody>
<tr>
<td rowspan="3" align="left" height="0" valign="bottom" width="15"><br>
</td>
<td colspan="2" align="left" height="78" valign="top" width="0">
<p class="style4">Milo van der Linden
<br>
<a href="skype:milovanderlinden?add">skype: milovanderlinden</a><br>
<a href="mailto:mlinden@zeelandnet.nl">mlinden@zeelandnet.nl</a><br>
<a href="mailto:milovanderlinden@gmail.com">milovanderlinden@gmail.com</a><br>
<a href="mailto:milo@3dsite.nl">milo@3dsite.nl</a><br>
<a href="http://www.3dsite.nl">http://www.3dsite.nl</a><br>
</p>
</td>
<td rowspan="3" align="left" height="0" valign="top" width="15"> </td>
<td valign="top" width="300">
<p class="style5"><span lang="NL">De informatie in dit bericht
reflecteert mijn persoonlijke mening en niet die van een bedrijf of
instantie. Aan de informatie kunnen geen rechten worden ontleend.
Indien dit bericht onderdeel is van een forum, mailing-list of
community dan gelden automatisch de bij het betreffende medium
behorende voorwaarden.</span>
<span lang="EN">The information in this message reflects my
personal opinion and not that of a company or public body. All rights
reserved.If this message is contained in a mailing-list or community,
the rights on the medium are automatically adapted.</span></p>
</td>
</tr>
</tbody>
</table>
</div>
</body>
</html>