[postgis-tickets] [PostGIS] #3495: AddGeometryColumn relies on table being in search_path
PostGIS
trac at osgeo.org
Tue Mar 8 09:17:17 PST 2016
#3495: AddGeometryColumn relies on table being in search_path
----------------------+---------------------------
Reporter: robe | Owner: pramsey
Type: defect | Status: new
Priority: blocker | Milestone: PostGIS 2.2.2
Component: postgis | Version: 2.2.x
Resolution: | Keywords:
----------------------+---------------------------
Description changed by robe:
Old description:
> Okay discovered an isssue with my search_path setting logic.
> The way our AddGeometryColumn works. The version that doesn't take
> schema requires the table with geometry column being added has schema
> set.
>
> I discovered this issue with
>
> {{{
> CREATE SCHEMA postgis VERSION "2.3.0dev";
> CREATE EXTENSION postgis SCHEMA postgis;
> ALTER DATABASE workshop_1
> SET search_path = public, postgis;
>
> -- and then using shp2pgsql to restore
> shp2pgsql -I -D -s 26986 data/MBTA_ARC mbta_lines | psql
>
> }}}
>
> {{{
> ALTER TABLE
> ERROR: Table 'mbta_lines' does not occur in the search_path
> CONTEXT: SQL statement "SELECT
> AddGeometryColumn('',$1,$2,$3,$4,$5,$6,$7)"
> PL/pgSQL function addgeometrycolumn(character varying,character
> varying,character varying,integer,character varying,integer,boolean) line
> 5 at SQL statement
> ERROR: current transaction is aborted, commands ignored until end of
> transaction block
> invalid command \.
> ERROR: syntax error at or near "GREEN"
> LINE 1: GREEN C D 7 4.58386095740e+002 01050000206A69000001000000010...
> ^
> ROLLBACK
> ERROR: relation "mbta_lines" does not exist
>
> }}}
>
> So I guess we've got to exclude all these from my search_path logic I put
> in on #3490. Eventually I think we'll need to force everyone to install
> postgis in same schema and schema qualify at least these ones and
> relationship ones that rely on users schema to be in search path to work
> well.
New description:
Okay discovered an isssue with my search_path setting logic.
The way our AddGeometryColumn works. The version that doesn't take schema
requires the table with geometry column being added has schema set.
I discovered this issue with
{{{
CREATE SCHEMA postgis VERSION "2.3.0dev";
CREATE EXTENSION postgis SCHEMA postgis;
ALTER DATABASE workshop_1
SET search_path = public, postgis;
-- and then using shp2pgsql to restore
shp2pgsql -I -D -s 26986 data/MBTA_ARC mbta_lines | psql
}}}
{{{
ALTER TABLE
ERROR: Table 'mbta_lines' does not occur in the search_path
CONTEXT: SQL statement "SELECT
AddGeometryColumn('',$1,$2,$3,$4,$5,$6,$7)"
PL/pgSQL function addgeometrycolumn(character varying,character
varying,character varying,integer,character varying,integer,boolean) line
5 at SQL statement
ERROR: current transaction is aborted, commands ignored until end of
transaction block
invalid command \.
ERROR: syntax error at or near "GREEN"
LINE 1: GREEN C D 7 4.58386095740e+002 01050000206A69000001000000010...
^
ROLLBACK
ERROR: relation "mbta_lines" does not exist
}}}
however this works okay -specifying schema of table
{{{
-- and then using shp2pgsql to restore
shp2pgsql -I -D -s 26986 data/MBTA_ARC public.mbta_lines | psql
}}}
So I guess we've got to exclude all these from my search_path logic I put
in on #3490. Eventually I think we'll need to force everyone to install
postgis in same schema and schema qualify at least these ones and
relationship ones that rely on users schema to be in search path to work
well.
--
--
Ticket URL: <https://trac.osgeo.org/postgis/ticket/3495#comment:1>
PostGIS <http://trac.osgeo.org/postgis/>
The PostGIS Trac is used for bug, enhancement & task tracking, a user and developer wiki, and a view into the subversion code repository of PostGIS project.
More information about the postgis-tickets
mailing list