[postgis-users] How best to do this?
Mark Thomas
spatialguru.net at gmail.com
Fri Feb 2 11:23:35 PST 2007
For the error with Union, I had this happen yesterday. To solve, I used
Simplify(geom,<very small number>) before passing to GeomUnion. that might
work for you.
On 2/2/07, postgis-users-request at postgis.refractions.net <
postgis-users-request at postgis.refractions.net> wrote:
>
> Send postgis-users mailing list submissions to
> postgis-users at postgis.refractions.net
>
> To subscribe or unsubscribe via the World Wide Web, visit
> http://postgis.refractions.net/mailman/listinfo/postgis-users
> or, via email, send a message with subject or body 'help' to
> postgis-users-request at postgis.refractions.net
>
> You can reach the person managing the list at
> postgis-users-owner at postgis.refractions.net
>
> When replying, please edit your Subject line so it is more specific
> than "Re: Contents of postgis-users digest..."
>
>
> Today's Topics:
>
> 1. How best to do this? (Stephen Woodbridge)
> 2. Re: How best to do this? (Stephen Woodbridge)
> 3. Re: How best to do this? (Paul Ramsey)
> 4. Re: pg_restore problem - linked to different versions?
> (Mark Cave-Ayland)
> 5. Errors in jdbc rpm build on Fedora Core 6 (Dido)
> 6. Re: pg_restore problem - linked to different versions?
> (Stefan Schwarzer)
> 7. Re: How best to do this? (Stephen Woodbridge)
> 8. Re: How best to do this? (Paul Ramsey)
> 9. Lat/lon bounding box to area? (Steve Benzo)
>
>
> ----------------------------------------------------------------------
>
> Message: 1
> Date: Thu, 01 Feb 2007 22:34:38 -0500
> From: Stephen Woodbridge <woodbri at swoodbridge.com>
> Subject: [postgis-users] How best to do this?
> To: PostGIS Users Discussion <postgis-users at postgis.refractions.net>
> Message-ID: <45C2B14E.2070904 at swoodbridge.com>
> Content-Type: text/plain; charset=UTF-8; format=flowed
>
> Hi all,
>
> Sorry the subject line is not more useful, but let me explain.
>
> 1) I have a set of polgons A and another set of polygon B
> 2) I need to a new set of polygons C that are the union of
> A intersect B and A difference B
>
> So basically B partially covers A and I want to split polygons in a into
> the covered piece(s) and that that is not covered.
>
> On the surface this is very straight forward, but it isn't ...
>
> insert into newtable (....)
> select ..., intersection(A.the_geom, B.the_geom) as the_geom
> from A, B
> where A.the_geom && B.the_geom and
> intersects(A.the_geom, B.the_geom);
>
> This works, but I get a bunch of GEOMETRYCOLLECTION objects in the
> results and out of 1022 collection I have 2780 additional POLYGONs.
>
> So I could do something like:
>
> insert into newtable (....)
> select * from
> (select ..., (dump(the_geom)).geom as the_geom from newtable
> where geometrytype(the_geom)='GEOMETRYCOLLECTION' ) as foo
> where geometrytype(the_geom)='POLYGON';
>
> delete from newtable where geometrytype(the_geom)='GEOMETRYCOLLECTION';
>
> So now comes the tricky part how do you do the difference? I was
> thinking I could take A difference newtable but because I have multiple
> little pieces instead of a single piece, I think I am getting:
> (A - Part1), (A - Part2), (A - Part3) instead of
> (A - Part1 - Part2 - Part3)
>
> So I think I need to union the polygon pieces from each row that is
> dumped above. Is that as simple as tossing part of the dump into a
> geomunion()? How would that look?
>
> -Steve W
>
>
> ------------------------------
>
> Message: 2
> Date: Fri, 02 Feb 2007 00:01:39 -0500
> From: Stephen Woodbridge <woodbri at swoodbridge.com>
> Subject: Re: [postgis-users] How best to do this?
> To: PostGIS Users Discussion <postgis-users at postgis.refractions.net>
> Message-ID: <45C2C5B3.2020709 at swoodbridge.com>
> Content-Type: text/plain; charset=UTF-8; format=flowed
>
> OK, one step forward and two steps backward ...
>
> I was about to get rid of my gemetrycollections with:
>
> update newtable set the_geom =
> (select geomunion(geom1) from
> (select (dump(the_geom)).geom as geom1) as foo
> where geometrytype(geom1)='POLYGON'
> )
> where geometrytype(the_geom)='GEOMETRYCOLLECTION';
>
> This worked very nicely once I figured out that this was the way to
> solve the problem. So now each geometry collection is converted into a
> polygon or multipolygon and all the linestring and point artifacts of
> the intersection are removed.
>
> select distinct geometrytype(the_geom) from soils2;
> POLYGON
> MULTIPOLYGON
>
> select * from soils where not isvalid(the_geom);
> reports 0 rows
>
> insert into newtable (..., the_geom)
> select A....,
> difference(A.the_geom, B.the_geom) as the_geom
> from A, B
> where A.the_geom && B.the_geom and overlaps(A.the_geom, B.the_geom);
>
> NOTICE: TopologyException: no outgoing dirEdge found
> (287030,892621,892621)
>
> ERROR: GEOS difference() threw an error!
>
> Now what do I do??? If I have to upgrade it might be easiest to upgrade
> my WinXP laptop if there is an easy way to do that, then dump and load
> the data to that.
>
> select postgis_full_version();
> "POSTGIS="1.1.5" GEOS="2.2.3-CAPI-1.1.1" PROJ="Rel. 4.4.9, 29 Oct 2004"
> USE_STATS (procs from 1.1.1 need upgrade)"
>
> select version();
> "PostgreSQL 8.0.8 on i386-portbld-freebsd5.3, compiled by GCC cc (GCC)
> 3.4.2 [FreeBSD] 20040728"
>
> -Steve
>
> Stephen Woodbridge wrote:
> > Hi all,
> >
> > Sorry the subject line is not more useful, but let me explain.
> >
> > 1) I have a set of polgons A and another set of polygon B
> > 2) I need to a new set of polygons C that are the union of
> > A intersect B and A difference B
> >
> > So basically B partially covers A and I want to split polygons in a into
> > the covered piece(s) and that that is not covered.
> >
> > On the surface this is very straight forward, but it isn't ...
> >
> > insert into newtable (....)
> > select ..., intersection(A.the_geom, B.the_geom) as the_geom
> > from A, B
> > where A.the_geom && B.the_geom and
> > intersects(A.the_geom, B.the_geom);
> >
> > This works, but I get a bunch of GEOMETRYCOLLECTION objects in the
> > results and out of 1022 collection I have 2780 additional POLYGONs.
> >
> > So I could do something like:
> >
> > insert into newtable (....)
> > select * from
> > (select ..., (dump(the_geom)).geom as the_geom from newtable
> > where geometrytype(the_geom)='GEOMETRYCOLLECTION' ) as foo
> > where geometrytype(the_geom)='POLYGON';
> >
> > delete from newtable where geometrytype(the_geom)='GEOMETRYCOLLECTION';
> >
> > So now comes the tricky part how do you do the difference? I was
> > thinking I could take A difference newtable but because I have multiple
> > little pieces instead of a single piece, I think I am getting:
> > (A - Part1), (A - Part2), (A - Part3) instead of
> > (A - Part1 - Part2 - Part3)
> >
> > So I think I need to union the polygon pieces from each row that is
> > dumped above. Is that as simple as tossing part of the dump into a
> > geomunion()? How would that look?
> >
> > -Steve W
> > _______________________________________________
> > postgis-users mailing list
> > postgis-users at postgis.refractions.net
> > http://postgis.refractions.net/mailman/listinfo/postgis-users
>
>
>
> ------------------------------
>
> Message: 3
> Date: Thu, 1 Feb 2007 21:14:22 -0800
> From: Paul Ramsey <pramsey at refractions.net>
> Subject: Re: [postgis-users] How best to do this?
> To: PostGIS Users Discussion <postgis-users at postgis.refractions.net>
> Message-ID: <D2E872F9-F43D-41DE-868C-F936776CECAD at refractions.net>
> Content-Type: text/plain; charset=US-ASCII; delsp=yes; format=flowed
>
> GEOS 3 does include a number of fixes that will help difference and
> union.
>
> P
>
> On 1-Feb-07, at 9:01 PM, Stephen Woodbridge wrote:
>
> > OK, one step forward and two steps backward ...
> >
> > I was about to get rid of my gemetrycollections with:
> >
> > update newtable set the_geom =
> > (select geomunion(geom1) from
> > (select (dump(the_geom)).geom as geom1) as foo
> > where geometrytype(geom1)='POLYGON'
> > )
> > where geometrytype(the_geom)='GEOMETRYCOLLECTION';
> >
> > This worked very nicely once I figured out that this was the way to
> > solve the problem. So now each geometry collection is converted
> > into a polygon or multipolygon and all the linestring and point
> > artifacts of the intersection are removed.
> >
> > select distinct geometrytype(the_geom) from soils2;
> > POLYGON
> > MULTIPOLYGON
> >
> > select * from soils where not isvalid(the_geom);
> > reports 0 rows
> >
> > insert into newtable (..., the_geom)
> > select A....,
> > difference(A.the_geom, B.the_geom) as the_geom
> > from A, B
> > where A.the_geom && B.the_geom and overlaps(A.the_geom, B.the_geom);
> >
> > NOTICE: TopologyException: no outgoing dirEdge found
> > (287030,892621,892621)
> >
> > ERROR: GEOS difference() threw an error!
> >
> > Now what do I do??? If I have to upgrade it might be easiest to
> > upgrade my WinXP laptop if there is an easy way to do that, then
> > dump and load the data to that.
> >
> > select postgis_full_version();
> > "POSTGIS="1.1.5" GEOS="2.2.3-CAPI-1.1.1" PROJ="Rel. 4.4.9, 29 Oct
> > 2004" USE_STATS (procs from 1.1.1 need upgrade)"
> >
> > select version();
> > "PostgreSQL 8.0.8 on i386-portbld-freebsd5.3, compiled by GCC cc
> > (GCC) 3.4.2 [FreeBSD] 20040728"
> >
> > -Steve
> >
> > Stephen Woodbridge wrote:
> >> Hi all,
> >> Sorry the subject line is not more useful, but let me explain.
> >> 1) I have a set of polgons A and another set of polygon B
> >> 2) I need to a new set of polygons C that are the union of
> >> A intersect B and A difference B
> >> So basically B partially covers A and I want to split polygons in
> >> a into the covered piece(s) and that that is not covered.
> >> On the surface this is very straight forward, but it isn't ...
> >> insert into newtable (....)
> >> select ..., intersection(A.the_geom, B.the_geom) as the_geom
> >> from A, B
> >> where A.the_geom && B.the_geom and
> >> intersects(A.the_geom, B.the_geom);
> >> This works, but I get a bunch of GEOMETRYCOLLECTION objects in the
> >> results and out of 1022 collection I have 2780 additional POLYGONs.
> >> So I could do something like:
> >> insert into newtable (....)
> >> select * from
> >> (select ..., (dump(the_geom)).geom as the_geom from newtable
> >> where geometrytype(the_geom)='GEOMETRYCOLLECTION' ) as foo
> >> where geometrytype(the_geom)='POLYGON';
> >> delete from newtable where geometrytype(the_geom)
> >> ='GEOMETRYCOLLECTION';
> >> So now comes the tricky part how do you do the difference? I was
> >> thinking I could take A difference newtable but because I have
> >> multiple little pieces instead of a single piece, I think I am
> >> getting:
> >> (A - Part1), (A - Part2), (A - Part3) instead of
> >> (A - Part1 - Part2 - Part3)
> >> So I think I need to union the polygon pieces from each row that
> >> is dumped above. Is that as simple as tossing part of the dump
> >> into a geomunion()? How would that look?
> >> -Steve W
> >> _______________________________________________
> >> postgis-users mailing list
> >> postgis-users at postgis.refractions.net
> >> http://postgis.refractions.net/mailman/listinfo/postgis-users
> >
> > _______________________________________________
> > postgis-users mailing list
> > postgis-users at postgis.refractions.net
> > http://postgis.refractions.net/mailman/listinfo/postgis-users
>
>
>
> ------------------------------
>
> Message: 4
> Date: Fri, 02 Feb 2007 12:25:19 +0000
> From: Mark Cave-Ayland <mark.cave-ayland at ilande.co.uk>
> Subject: Re: [postgis-users] pg_restore problem - linked to different
> versions?
> To: PostGIS Users Discussion <postgis-users at postgis.refractions.net>
> Message-ID: <1170419119.6358.10.camel at mca-desktop>
> Content-Type: text/plain
>
> On Thu, 2007-02-01 at 14:40 +0100, Stefan Schwarzer wrote:
> > Hi,
> >
> > I dumped my locally newly created database and wanted to restore on
> > the server. But I got this message.
> >
> > pg_restore: [archiver] unsupported version (1.10) in file header
> > pg_restore: [archiver] unsupported version (1.10) in file header
> > pg_restore call failed
> >
> > I guess the problem comes from the fact that:
> >
> > the server runs with PostGres 8.1.0 and PostGIS 1.1.2
> > my local machine with PostGres 8.1.2 and PostGIS 1.1.1
> >
> > Could that be? And what can I do to solve the problem? In the moment
> > we won't touch our server, as it runs smoothly. And on my local
> > machine, a Mac, the different packages have been installed via the
> > prebuild packages from KyngChaos. I am no compiler.... So, not too
> > keen to re-compile Postgres and Postgis.... But I guess it's what I
> > have to do, right?
> >
> > Thanks for any hints...
>
>
> Hi Stefan,
>
> Could it be that you have multiple versions of pg_restore on your
> server? Looking at the PostgreSQL source code, version 1.10 headers were
> introduced with the advent of tablespaces (PostgreSQL 8.0) and so you
> are attempting to restore your pg_dump with a pg_restore for PostgreSQL
> < 8.0.
>
> So you need to check your paths and make sure you are using the
> pg_restore from your PostgreSQL 8.1 installation. Perhaps if you
> installed PostgreSQL 8.1 yourself, you need to be using the version
> in /usr/local/bin rather than the version in /usr/bin which originally
> came with your distro?
>
>
> Kind regards,
>
> Mark.
>
>
>
>
> ------------------------------
>
> Message: 5
> Date: Fri, 02 Feb 2007 16:04:01 +0200
> From: Dido <dido+postgis at sarge.mine.nu>
> Subject: [postgis-users] Errors in jdbc rpm build on Fedora Core 6
> To: PostGIS Users Discussion <postgis-users at postgis.refractions.net>
> Message-ID: <20070202160401.03ovwnsug400s8og at mx2.sofita.com>
> Content-Type: text/plain;
> charset=UTF-8; DelSp="Yes"; format="flowed"
>
> Hi @,
> I'm trying to make postgis 1.2.1 Fedora Core 6 rpm package, but I have
> some errors.
> Also I would like to make postgis rpm against postgresql 8.2.1 , did
> someone have feedback ?
>
> Here is list of postgres and java packages:
> [root at fc-test ~]# rpm -qa | grep postgres
> postgresql-server-8.1.6-1.fc6
> postgresql-docs-8.1.6-1.fc6
> postgresql-8.1.6-1.fc6
> postgresql-devel-8.1.6-1.fc6
> postgresql-libs-8.1.6-1.fc6
> postgresql-contrib-8.1.6-1.fc6
> postgresql-jdbc-8.1.407-1jpp.4
> [root at fc-test ~]# rpm -qa | grep java
> java-1.4.2-gcj-compat-1.4.2.0-40jpp.110
> gcc-java-4.1.1-51.fc6
> java-1.4.2-gcj-compat-devel-1.4.2.0-40jpp.110
>
> I'm using following SPEC file from 1.2.0, with version change
>
> [root at fc-test ~]# cat /usr/src/redhat/SPECS/postgis.spec
> %{!?javabuild:%define javabuild 1}
> %{!?utils:%define utils 1}
> %{!?gcj_support:%define gcj_support 1}
>
> Summary: Geographic Information Systems Extensions to PostgreSQL
> Name: postgis
> Version: 1.2.1
> Release: 2%{?dist}
> License: GPL
> Group: Applications/Databases
> Source0:
> http://postgis.refractions.net/download/%{name}-%{version}.tar.gz
> Source4: filter-requires-perl-Pg.sh
> #Patch1: postgis-configure.patch
> Patch2: postgis-javamakefile.patch
> URL: http://postgis.refractions.net/
> BuildRoot: %{_tmppath}/%{name}-%{version}-%{release}-root-%(%{__id_u}
> -n)
>
> BuildRequires: postgresql-devel, proj-devel, geos-devel, byacc,
> proj-devel, flex, postgresql-jdbc
> Requires: postgresql, geos, proj
>
> %description
> PostGIS adds support for geographic objects to the PostgreSQL
> object-relational
> database. In effect, PostGIS "spatially enables" the PostgreSQL server,
> allowing it to be used as a backend spatial database for geographic
> information
> systems (GIS), much like ESRI's SDE or Oracle's Spatial extension. PostGIS
> follows the OpenGIS "Simple Features Specification for SQL" and has been
> certified as compliant with the "Types and Functions" profile.
>
> %if %javabuild
> %package jdbc
> Summary: The JDBC driver for PostGIS
> Group: Applications/Databases
> License: LGPL
> Requires: postgis
> BuildRequires: ant >= 0:1.6.2, junit >= 0:3.7
>
> %if %{gcj_support}
> BuildRequires: gcc-java
> Requires(post): java-1.4.2-gcj-compat
> Requires(postun): java-1.4.2-gcj-compat
> %endif
>
> %description jdbc
> The postgis-jdbc package provides the essential jdbc driver for PostGIS.
> %endif
>
> %if %utils
> %package utils
> Summary: The utils for PostGIS
> Group: Applications/Databases
> Requires: postgis, perl-DBD-Pg
>
> %description utils
> The postgis-utils package provides the utilities for PostGIS.
> %endif
>
> %define __perl_requires %{SOURCE4}
>
> %prep
> %setup -q
> #%patch1 -p0
> %patch2 -p0
>
> %build
> %configure
> make %{?_smp_mflags} LPATH=`pg_config --pkglibdir` shlib="%{name}.so"
>
> %if %javabuild
> export MAKEFILE_DIR=%{_builddir}/%{name}-%{version}/java/jdbc
> JDBC_VERSION_RPM=`rpm -ql postgresql-jdbc| grep 'jdbc.jar$'|awk -F '/'
> '{print $5}'`
> sed 's/postgresql.jar/'${JDBC_VERSION_RPM}'/g' $MAKEFILE_DIR/Makefile
> > $MAKEFILE_DIR/Makefile.new
> mv -f $MAKEFILE_DIR/Makefile.new $MAKEFILE_DIR/Makefile
> make -C java/jdbc
> %endif
>
> %if %utils
> make -C utils
> %endif
>
> %install
> rm -rf %{buildroot}
> make install DESTDIR=%{buildroot}
> install -d %{buildroot}%{_libdir}/pgsql/
> install lwgeom/liblwgeom.so* %{buildroot}%{_libdir}/pgsql/
> install -d %{buildroot}%{_datadir}/pgsql/contrib/
> install -m 644 *.sql %{buildroot}%{_datadir}/pgsql/contrib/
> rm -f %{buildroot}%{_libdir}/liblwgeom.so*
> rm -f %{buildroot}%{_datadir}/*.sql
>
> %if %javabuild
> install -d %{buildroot}%{_javadir}
> install -m 755 java/jdbc/%{name}_%{version}.jar %{buildroot}%{_javadir}
> %if %{gcj_support}
> aot-compile-rpm
> %endif
> %endif
>
> strip %{buildroot}/%{_libdir}/gcj/%{name}/*.jar.so
>
> %if %utils
> install -d %{buildroot}%{_datadir}/%{name}
> install -m 644 utils/*.pl %{buildroot}%{_datadir}/%{name}
> %endif
>
> %clean
> rm -rf %{buildroot}
>
> %post -p %{_bindir}/rebuild-gcj-db
>
> %postun -p %{_bindir}/rebuild-gcj-db
>
> %files
> %defattr(-,root,root)
> %doc COPYING CREDITS NEWS TODO README.%{name} TODO doc/html
> loader/README.* doc/%{name}.xml doc/ZMSgeoms.txt
> %attr(755,root,root) %{_bindir}/*
> %attr(755,root,root) %{_libdir}/pgsql/liblwgeom.so*
> %{_datadir}/pgsql/contrib/*.sql
>
> %if %javabuild
> %files jdbc
> %defattr(-,root,root)
> %doc java/jdbc/COPYING_LGPL java/jdbc/README
> %attr(755,root,root) %{_javadir}/%{name}_%{version}.jar
> %if %{gcj_support}
> %dir %{_libdir}/gcj/%{name}
> %{_libdir}/gcj/%{name}/*.jar.so
> %{_libdir}/gcj/%{name}/*.jar.db
> %endif
> %endif
>
> %if %utils
> %files utils
> %defattr(-,root,root)
> %doc utils/README
> %attr(755,root,root) %{_datadir}/%{name}/test_estimation.pl
> %attr(755,root,root) %{_datadir}/%{name}/profile_intersects.pl
> %attr(755,root,root) %{_datadir}/%{name}/test_joinestimation.pl
> %attr(644,root,root) %{_datadir}/%{name}/create_undef.pl
> %attr(644,root,root) %{_datadir}/%{name}/%{name}_proc_upgrade.pl
> %attr(644,root,root) %{_datadir}/%{name}/%{name}_restore.pl
> %endif
>
> %changelog
> * Mon Dec 26 2006 - Devrim GUNDUZ <devrim at commandprompt.com> 1.2.0-2
> - More spec file fixes per bugzilla review #220743
>
> ----------------------------------------------------- errors log here:
> -----------
>
> + make -C java/jdbc
> ----------
> 1. ERROR in ./src/org/postgis/ComposedGeom.java (at line 29)
> import org.postgresql.util.PGtokenizer;
> ^^^^^^^^^^^^^^^^^^^
> The import org.postgresql.util cannot be resolved
> ----------
> 2. ERROR in ./src/org/postgis/ComposedGeom.java (at line 104)
> PGtokenizer t = new PGtokenizer(PGtokenizer.removePara(value),
> ',');
> ^^^^^^^^^^^
> PGtokenizer cannot be resolved to a type
> ----------
> 3. ERROR in ./src/org/postgis/ComposedGeom.java (at line 104)
> PGtokenizer t = new PGtokenizer(PGtokenizer.removePara(value),
> ',');
> ^^^^^^^^^^^
> PGtokenizer cannot be resolved to a type
> ----------
> 4. ERROR in ./src/org/postgis/ComposedGeom.java (at line 104)
> PGtokenizer t = new PGtokenizer(PGtokenizer.removePara(value),
> ',');
> ^^^^^^^^^^^
> PGtokenizer cannot be resolved
> ----------
> ----------
> 5. ERROR in ./src/org/postgis/DriverWrapper.java (at line 72)
> public class DriverWrapper extends Driver {
> ^^^^^^
> Driver cannot be resolved to a type
> ----------
> ----------
> 6. ERROR in ./src/org/postgis/DriverWrapperAutoprobe.java (at line 54)
> public class DriverWrapperAutoprobe extends DriverWrapper {
> ^^^^^^^^^^^^^^^^^^^^^^
> The hierarchy of the type DriverWrapperAutoprobe is inconsistent
> ----------
> ----------
> 7. ERROR in ./src/org/postgis/DriverWrapperLW.java (at line 49)
> public class DriverWrapperLW extends DriverWrapper {
> ^^^^^^^^^^^^^^^
> The hierarchy of the type DriverWrapperLW is inconsistent
> ----------
> ----------
> 8. ERROR in ./src/org/postgis/PGbox2d.java (at line 31)
> public class PGbox2d extends PGboxbase {
> ^^^^^^^
> The hierarchy of the type PGbox2d is inconsistent
> ----------
> ----------
> 9. ERROR in ./src/org/postgis/PGbox3d.java (at line 32)
> public class PGbox3d extends PGboxbase {
> ^^^^^^^
> The hierarchy of the type PGbox3d is inconsistent
> ----------
> ----------
> 10. ERROR in ./src/org/postgis/PGboxbase.java (at line 40)
> public abstract class PGboxbase extends PGobject {
> ^^^^^^^^
> PGobject cannot be resolved to a type
> ----------
> ----------
> 11. ERROR in ./src/org/postgis/PGgeometry.java (at line 34)
> public class PGgeometry extends PGobject {
> ^^^^^^^^
> PGobject cannot be resolved to a type
> ----------
> ----------
> 12. ERROR in ./src/org/postgis/PGgeometryLW.java (at line 37)
> public class PGgeometryLW extends PGgeometry {
> ^^^^^^^^^^^^
> The hierarchy of the type PGgeometryLW is inconsistent
> ----------
> ----------
> 13. ERROR in ./src/org/postgis/java2d/Java2DWrapper.java (at line 50)
> public class Java2DWrapper extends Driver {
> ^^^^^^
> Driver cannot be resolved to a type
> ----------
> ----------
> 14. ERROR in ./src/org/postgis/java2d/PGShapeGeometry.java (at line 63)
> public class PGShapeGeometry extends PGobject implements Shape {
> ^^^^^^^^
> PGobject cannot be resolved to a type
> ----------
> 14 problems (14 errors)make: *** [compile] Error 255
> error: Bad exit status from /var/tmp/rpm-tmp.18862 (%build)
>
> How I can tackle with this situation ?
>
> Best regards,
> Dido
>
>
>
> ------------------------------
>
> Message: 6
> Date: Fri, 2 Feb 2007 15:27:33 +0100
> From: Stefan Schwarzer <stefan.schwarzer at grid.unep.ch>
> Subject: Re: [postgis-users] pg_restore problem - linked to different
> versions?
> To: PostGIS Users Discussion <postgis-users at postgis.refractions.net>
> Message-ID: <85D74A20-1E59-4D92-A4D4-57DD74CAF1B1 at grid.unep.ch>
> Content-Type: text/plain; charset=US-ASCII; delsp=yes; format=flowed
>
> >> I dumped my locally newly created database and wanted to restore on
> >> the server. But I got this message.
> >>
> >> pg_restore: [archiver] unsupported version (1.10) in file header
> >> pg_restore: [archiver] unsupported version (1.10) in file header
> >> pg_restore call failed
> >>
> >> I guess the problem comes from the fact that:
> >>
> >> the server runs with PostGres 8.1.0 and PostGIS 1.1.2
> >> my local machine with PostGres 8.1.2 and PostGIS 1.1.1
> >>
> >> Could that be? And what can I do to solve the problem? In the moment
> >> we won't touch our server, as it runs smoothly. And on my local
> >> machine, a Mac, the different packages have been installed via the
> >> prebuild packages from KyngChaos. I am no compiler.... So, not too
> >> keen to re-compile Postgres and Postgis.... But I guess it's what I
> >> have to do, right?
> >>
> >> Thanks for any hints...
> >
> >
> > Hi Stefan,
> >
> > Could it be that you have multiple versions of pg_restore on your
> > server? Looking at the PostgreSQL source code, version 1.10 headers
> > were
> > introduced with the advent of tablespaces (PostgreSQL 8.0) and so you
> > are attempting to restore your pg_dump with a pg_restore for
> > PostgreSQL
> > < 8.0.
> >
> > So you need to check your paths and make sure you are using the
> > pg_restore from your PostgreSQL 8.1 installation. Perhaps if you
> > installed PostgreSQL 8.1 yourself, you need to be using the version
> > in /usr/local/bin rather than the version in /usr/bin which originally
> > came with your distro?
>
> Great Mark,
>
> you were absolutely right! There were two or three references to
> pg_restore; only one of them version 8, and not the default one.
>
> Thanks a lot!!!
>
>
>
> ------------------------------
>
> Message: 7
> Date: Fri, 02 Feb 2007 12:03:37 -0500
> From: Stephen Woodbridge <woodbri at swoodbridge.com>
> Subject: Re: [postgis-users] How best to do this?
> To: PostGIS Users Discussion <postgis-users at postgis.refractions.net>
> Message-ID: <45C36EE9.6050403 at swoodbridge.com>
> Content-Type: text/plain; charset=ISO-8859-1; format=flowed
>
> Paul, et al,
>
> Any chance that someone would have GEOS 3 built for WinXP that I could
> drop into a system currently running:
>
> "POSTGIS="1.1.3" GEOS="2.2.2-CAPI-1.1.0" PROJ="Rel. 4.4.9, 29 Oct 2004"
> USE_STATS"
>
> "PostgreSQL 8.1.4 on i686-pc-mingw32, compiled by GCC gcc.exe (GCC)
> 3.4.2 (mingw-special)"
>
> So I could give this a try.
>
> In the past, I seem to remember people dealing with these problems using
> snaptogrid() - would this potentially help here and how would I change
> my query to use that?
>
> -Steve
>
> Paul Ramsey wrote:
> > GEOS 3 does include a number of fixes that will help difference and
> union.
> >
> > P
> >
> > On 1-Feb-07, at 9:01 PM, Stephen Woodbridge wrote:
> >
> >> OK, one step forward and two steps backward ...
> >>
> >> I was about to get rid of my gemetrycollections with:
> >>
> >> update newtable set the_geom =
> >> (select geomunion(geom1) from
> >> (select (dump(the_geom)).geom as geom1) as foo
> >> where geometrytype(geom1)='POLYGON'
> >> )
> >> where geometrytype(the_geom)='GEOMETRYCOLLECTION';
> >>
> >> This worked very nicely once I figured out that this was the way to
> >> solve the problem. So now each geometry collection is converted into a
> >> polygon or multipolygon and all the linestring and point artifacts of
> >> the intersection are removed.
> >>
> >> select distinct geometrytype(the_geom) from soils2;
> >> POLYGON
> >> MULTIPOLYGON
> >>
> >> select * from soils where not isvalid(the_geom);
> >> reports 0 rows
> >>
> >> insert into newtable (..., the_geom)
> >> select A....,
> >> difference(A.the_geom, B.the_geom) as the_geom
> >> from A, B
> >> where A.the_geom && B.the_geom and overlaps(A.the_geom, B.the_geom);
> >>
> >> NOTICE: TopologyException: no outgoing dirEdge found
> >> (287030,892621,892621)
> >>
> >> ERROR: GEOS difference() threw an error!
> >>
> >> Now what do I do??? If I have to upgrade it might be easiest to
> >> upgrade my WinXP laptop if there is an easy way to do that, then dump
> >> and load the data to that.
> >>
> >> select postgis_full_version();
> >> "POSTGIS="1.1.5" GEOS="2.2.3-CAPI-1.1.1" PROJ="Rel. 4.4.9, 29 Oct
> >> 2004" USE_STATS (procs from 1.1.1 need upgrade)"
> >>
> >> select version();
> >> "PostgreSQL 8.0.8 on i386-portbld-freebsd5.3, compiled by GCC cc (GCC)
> >> 3.4.2 [FreeBSD] 20040728"
> >>
> >> -Steve
> >>
> >> Stephen Woodbridge wrote:
> >>> Hi all,
> >>> Sorry the subject line is not more useful, but let me explain.
> >>> 1) I have a set of polgons A and another set of polygon B
> >>> 2) I need to a new set of polygons C that are the union of
> >>> A intersect B and A difference B
> >>> So basically B partially covers A and I want to split polygons in a
> >>> into the covered piece(s) and that that is not covered.
> >>> On the surface this is very straight forward, but it isn't ...
> >>> insert into newtable (....)
> >>> select ..., intersection(A.the_geom, B.the_geom) as the_geom
> >>> from A, B
> >>> where A.the_geom && B.the_geom and
> >>> intersects(A.the_geom, B.the_geom);
> >>> This works, but I get a bunch of GEOMETRYCOLLECTION objects in the
> >>> results and out of 1022 collection I have 2780 additional POLYGONs.
> >>> So I could do something like:
> >>> insert into newtable (....)
> >>> select * from
> >>> (select ..., (dump(the_geom)).geom as the_geom from newtable
> >>> where geometrytype(the_geom)='GEOMETRYCOLLECTION' ) as foo
> >>> where geometrytype(the_geom)='POLYGON';
> >>> delete from newtable where
> geometrytype(the_geom)='GEOMETRYCOLLECTION';
> >>> So now comes the tricky part how do you do the difference? I was
> >>> thinking I could take A difference newtable but because I have
> >>> multiple little pieces instead of a single piece, I think I am
> getting:
> >>> (A - Part1), (A - Part2), (A - Part3) instead of
> >>> (A - Part1 - Part2 - Part3)
> >>> So I think I need to union the polygon pieces from each row that is
> >>> dumped above. Is that as simple as tossing part of the dump into a
> >>> geomunion()? How would that look?
> >>> -Steve W
> >>> _______________________________________________
> >>> postgis-users mailing list
> >>> postgis-users at postgis.refractions.net
> >>> http://postgis.refractions.net/mailman/listinfo/postgis-users
> >>
> >> _______________________________________________
> >> postgis-users mailing list
> >> postgis-users at postgis.refractions.net
> >> http://postgis.refractions.net/mailman/listinfo/postgis-users
> >
> > _______________________________________________
> > postgis-users mailing list
> > postgis-users at postgis.refractions.net
> > http://postgis.refractions.net/mailman/listinfo/postgis-users
>
>
>
> ------------------------------
>
> Message: 8
> Date: Fri, 02 Feb 2007 09:25:43 -0800
> From: Paul Ramsey <pramsey at refractions.net>
> Subject: Re: [postgis-users] How best to do this?
> To: PostGIS Users Discussion <postgis-users at postgis.refractions.net>
> Message-ID: <45C37417.4070607 at refractions.net>
> Content-Type: text/plain; charset=ISO-8859-1; format=flowed
>
> snaptogrid might help, it is a crude hammer similar in many ways to the
> more subtle approaches in GEOS3.
>
> Because the C API didn't change between versions, you may be able to
> simply copy a suitably compiled geos DLL into place, perhaps by
> stripping one out of the windows downloads. I don't actually know if our
> windows downloads are using GEOS3 though... hrm. Mark CA?
>
> P
>
> Stephen Woodbridge wrote:
> > Paul, et al,
> >
> > Any chance that someone would have GEOS 3 built for WinXP that I could
> > drop into a system currently running:
> >
> > "POSTGIS="1.1.3" GEOS="2.2.2-CAPI-1.1.0" PROJ="Rel. 4.4.9, 29 Oct 2004"
> > USE_STATS"
> >
> > "PostgreSQL 8.1.4 on i686-pc-mingw32, compiled by GCC gcc.exe (GCC)
> > 3.4.2 (mingw-special)"
> >
> > So I could give this a try.
> >
> > In the past, I seem to remember people dealing with these problems using
> > snaptogrid() - would this potentially help here and how would I change
> > my query to use that?
> >
> > -Steve
> >
> > Paul Ramsey wrote:
> >> GEOS 3 does include a number of fixes that will help difference and
> >> union.
> >>
> >> P
> >>
> >> On 1-Feb-07, at 9:01 PM, Stephen Woodbridge wrote:
> >>
> >>> OK, one step forward and two steps backward ...
> >>>
> >>> I was about to get rid of my gemetrycollections with:
> >>>
> >>> update newtable set the_geom =
> >>> (select geomunion(geom1) from
> >>> (select (dump(the_geom)).geom as geom1) as foo
> >>> where geometrytype(geom1)='POLYGON'
> >>> )
> >>> where geometrytype(the_geom)='GEOMETRYCOLLECTION';
> >>>
> >>> This worked very nicely once I figured out that this was the way to
> >>> solve the problem. So now each geometry collection is converted into
> >>> a polygon or multipolygon and all the linestring and point artifacts
> >>> of the intersection are removed.
> >>>
> >>> select distinct geometrytype(the_geom) from soils2;
> >>> POLYGON
> >>> MULTIPOLYGON
> >>>
> >>> select * from soils where not isvalid(the_geom);
> >>> reports 0 rows
> >>>
> >>> insert into newtable (..., the_geom)
> >>> select A....,
> >>> difference(A.the_geom, B.the_geom) as the_geom
> >>> from A, B
> >>> where A.the_geom && B.the_geom and overlaps(A.the_geom, B.the_geom);
> >>>
> >>> NOTICE: TopologyException: no outgoing dirEdge found
> >>> (287030,892621,892621)
> >>>
> >>> ERROR: GEOS difference() threw an error!
> >>>
> >>> Now what do I do??? If I have to upgrade it might be easiest to
> >>> upgrade my WinXP laptop if there is an easy way to do that, then dump
> >>> and load the data to that.
> >>>
> >>> select postgis_full_version();
> >>> "POSTGIS="1.1.5" GEOS="2.2.3-CAPI-1.1.1" PROJ="Rel. 4.4.9, 29 Oct
> >>> 2004" USE_STATS (procs from 1.1.1 need upgrade)"
> >>>
> >>> select version();
> >>> "PostgreSQL 8.0.8 on i386-portbld-freebsd5.3, compiled by GCC cc
> >>> (GCC) 3.4.2 [FreeBSD] 20040728"
> >>>
> >>> -Steve
> >>>
> >>> Stephen Woodbridge wrote:
> >>>> Hi all,
> >>>> Sorry the subject line is not more useful, but let me explain.
> >>>> 1) I have a set of polgons A and another set of polygon B
> >>>> 2) I need to a new set of polygons C that are the union of
> >>>> A intersect B and A difference B
> >>>> So basically B partially covers A and I want to split polygons in a
> >>>> into the covered piece(s) and that that is not covered.
> >>>> On the surface this is very straight forward, but it isn't ...
> >>>> insert into newtable (....)
> >>>> select ..., intersection(A.the_geom, B.the_geom) as the_geom
> >>>> from A, B
> >>>> where A.the_geom && B.the_geom and
> >>>> intersects(A.the_geom, B.the_geom);
> >>>> This works, but I get a bunch of GEOMETRYCOLLECTION objects in the
> >>>> results and out of 1022 collection I have 2780 additional POLYGONs.
> >>>> So I could do something like:
> >>>> insert into newtable (....)
> >>>> select * from
> >>>> (select ..., (dump(the_geom)).geom as the_geom from newtable
> >>>> where geometrytype(the_geom)='GEOMETRYCOLLECTION' ) as foo
> >>>> where geometrytype(the_geom)='POLYGON';
> >>>> delete from newtable where
> geometrytype(the_geom)='GEOMETRYCOLLECTION';
> >>>> So now comes the tricky part how do you do the difference? I was
> >>>> thinking I could take A difference newtable but because I have
> >>>> multiple little pieces instead of a single piece, I think I am
> getting:
> >>>> (A - Part1), (A - Part2), (A - Part3) instead of
> >>>> (A - Part1 - Part2 - Part3)
> >>>> So I think I need to union the polygon pieces from each row that is
> >>>> dumped above. Is that as simple as tossing part of the dump into a
> >>>> geomunion()? How would that look?
> >>>> -Steve W
> >>>> _______________________________________________
> >>>> postgis-users mailing list
> >>>> postgis-users at postgis.refractions.net
> >>>> http://postgis.refractions.net/mailman/listinfo/postgis-users
> >>>
> >>> _______________________________________________
> >>> postgis-users mailing list
> >>> postgis-users at postgis.refractions.net
> >>> http://postgis.refractions.net/mailman/listinfo/postgis-users
> >>
> >> _______________________________________________
> >> postgis-users mailing list
> >> postgis-users at postgis.refractions.net
> >> http://postgis.refractions.net/mailman/listinfo/postgis-users
> >
> > _______________________________________________
> > postgis-users mailing list
> > postgis-users at postgis.refractions.net
> > http://postgis.refractions.net/mailman/listinfo/postgis-users
>
>
> --
>
> Paul Ramsey
> Refractions Research
> http://www.refractions.net
> pramsey at refractions.net
> Phone: 250-383-3022
> Cell: 250-885-0632
>
>
> ------------------------------
>
> Message: 9
> Date: Fri, 2 Feb 2007 10:40:36 -0800 (PST)
> From: Steve Benzo <steve_benzo at yahoo.com>
> Subject: [postgis-users] Lat/lon bounding box to area?
> To: postgis-users at postgis.refractions.net
> Message-ID: <404830.54155.qm at web56205.mail.re3.yahoo.com>
> Content-Type: text/plain; charset="iso-8859-1"
>
> Hi,
>
> This might be a stupid question, but is there a way using PostGIS that I
> can take a bounding box (polyline) supplied by a user (they're drawing a box
> on the map, from which I get the xmin/ymin/etc from), which I'd like to use
> to get an area from (utlimately acres). My first step will be to get that
> polyline into PostGIS (struggling, but should be able to figure it out) and
> then apply a trigger which populates an area field from that. Thanks in
> advance.
>
> SB
>
>
> ---------------------------------
> Check out the all-new Yahoo! Mail beta - Fire up a more powerful email and
> get things done faster.
> -------------- next part --------------
> An HTML attachment was scrubbed...
> URL:
> http://lists.refractions.net/pipermail/postgis-users/attachments/20070202/13939878/attachment-0001.html
>
> ------------------------------
>
> _______________________________________________
> postgis-users mailing list
> postgis-users at postgis.refractions.net
> http://postgis.refractions.net/mailman/listinfo/postgis-users
>
>
> End of postgis-users Digest, Vol 52, Issue 2
> ********************************************
>
--
Regards,
Mark Thomas
spatialguru.net at gmail.com
205.529.9013
"Commit to the Lord whatever you do,
and your plans will succeed." - Proverbs 16:3
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://lists.osgeo.org/pipermail/postgis-users/attachments/20070202/cad711fa/attachment.html>
More information about the postgis-users
mailing list