Re: CREATE RULE fails with 'ERROR: SELECT rule's target list has too many entries'

Поиск
Список
Период
Сортировка
От Tom Lane
Тема Re: CREATE RULE fails with 'ERROR: SELECT rule's target list has too many entries'
Дата
Msg-id 6213.1354723134@sss.pgh.pa.us
обсуждение исходный текст
Ответ на Re: CREATE RULE fails with 'ERROR: SELECT rule's target list has too many entries'  (Henrik Kuhn <henrik.kuhn@origenis.de>)
Ответы Re: CREATE RULE fails with 'ERROR: SELECT rule's target list has too many entries'
Список pgsql-general
Henrik Kuhn <henrik.kuhn@origenis.de> writes:
> On 12/05/2012 04:07 PM, Tom Lane wrote:
>> Henrik Kuhn <henrik.kuhn@origenis.de> writes:
>>> can somebody give me some insights why the creation of this rule fails
>> > with 'ERROR:  SELECT rule's target list has too many entries'?

>> Probably that history_relation has fewer than three columns?  But if
>> you want something more than guessing, you'd have to provide more
>> context, such as the definitions of the underlying tables.  Why are
>> you trying to execute this command anyway?

> The history_relatio-DDL is quite simple:

> CREATE TABLE history_relation (
>      id                  UUID NOT NULL DEFAULT uuid_generate_v4()
>    , relname        name NOT NULL CHECK ( relname::regclass IS NOT NULL
> ) -- use regclass to validate

>    , PRIMARY KEY (id)
> );

> But are your really sure, that the error is thrown just because of there
> are not more than 3 cols in history_relation?

Yes.  I think you misunderstand what that command is for: it's going to
convert the table into a view, and as a safety check it is not allowed
for the resulting view to have a different column set than the table
did.

I think what you need to do is create the underlying table with some
other name, create history_relation as a plain view, and then perhaps
you want some INSTEAD OF triggers on the view to convert insertions
etc into updates of the underlying table.

            regards, tom lane


В списке pgsql-general по дате отправления:

Предыдущее
От: Henrik Kuhn
Дата:
Сообщение: Re: CREATE RULE fails with 'ERROR: SELECT rule's target list has too many entries'
Следующее
От: JP
Дата:
Сообщение: Extending the KD Tree index in Postgresql 9.2.1