| From: | Stephan Szabo <sszabo(at)megazone(dot)bigpanda(dot)com> |
|---|---|
| To: | Daniel Naschenweng <daniel_blumenau(at)yahoo(dot)com(dot)br> |
| Cc: | pgsql-general(at)postgresql(dot)org |
| Subject: | Re: ERROR: cannot alter type of a column used by a view |
| Date: | 2005-02-16 13:25:18 |
| Message-ID: | 20050216051958.I34919@megazone.bigpanda.com |
| Views: | Whole Thread | Raw Message | Download mbox | Resend email |
| Thread: | |
| Lists: | pgsql-general |
On Wed, 16 Feb 2005, Daniel Naschenweng wrote:
> I create this table:
> create table teste (campo1 varchar(20));
>
> And this view:
> create view vteste as select * from teste;
>
> When I try change the type of the column raise thir error:
> db=# alter table teste alter column campo1 type varchar(30);
> ERROR: cannot alter type of a column used by a view or rule
> DETAIL: rule _RETURN on view vteste depends on column "campo1"
>
> My question is: Who I can create a "select" no system catalog to return
> views with this column befor raise error?
I haven't really tested it much, but I think something like the following
will work to give you the pg_class row for a view dependant on a
particular column.
select pg_class.* from pg_depend,pg_attribute,pg_rewrite,pg_class where
refclassid=1259 and
refobjid='teste'::regclass and
pg_attribute.attrelid='teste'::regclass and
refobjsubid = attnum and
attname='campo1' and
classid='pg_rewrite'::regclass and
pg_rewrite.oid=objid and
pg_rewrite.rulename='_RETURN' and
pg_class.oid=pg_rewrite.ev_class;
| From | Date | Subject | |
|---|---|---|---|
| Next Message | Matt Kynaston | 2005-02-16 13:32:25 | Re: insert data from an microsoft excel |
| Previous Message | Alban Hertroys | 2005-02-16 13:14:56 | Re: Lost rows/data corruption? |