Re: Fix error message when trying to alter statistics on included column

From: Robert Haas <robertmhaas(at)gmail(dot)com>
To: Yugo Nagata <nagata(at)sraoss(dot)co(dot)jp>
Cc: "pgsql-hackers(at)postgresql(dot)org" <pgsql-hackers(at)postgresql(dot)org>
Subject: Re: Fix error message when trying to alter statistics on included column
Date: 2018-07-02 18:23:09
Message-ID: CA+TgmoZFNDsgvy+pyfQyz9UQm0GHcHtoA=V51Ra6Lav+t1uFWg@mail.gmail.com
Views: Raw Message | Whole Thread | Download mbox | Resend email
Thread:
Lists: pgsql-hackers

On Thu, Jun 28, 2018 at 5:28 AM, Yugo Nagata <nagata(at)sraoss(dot)co(dot)jp> wrote:
> According to the error message, it is not allowed to alter statistics on
> included column because this is "non-expression column".
>
> postgres=# create table test (i int, d int);
> CREATE TABLE
> postgres=# create index idx on test(i) include (d);
> CREATE INDEX
> postgres=# alter index idx alter column 2 set statistics 10;
> ERROR: cannot alter statistics on non-expression column "d" of index "idx"
> HINT: Alter statistics on table column instead.
>
> However, I think this should be forbidded in that this is not a key column
> but a included column. Even if we decide to support expressions in included
> columns in future, it is meaningless to do this because any statistics on
> included column is never used by the planner.
>
> Attached is the patch to fix the error message. In this fix, column number
> is checked first. After applying this, the message is changed as below;
>
> postgres=# alter index idx alter column 2 set statistics 10;
> ERROR: cannot alter statistics on included column "d" of index "idx"

I think you should add an open item for this.

--
Robert Haas
EnterpriseDB: http://www.enterprisedb.com
The Enterprise PostgreSQL Company

In response to

Responses

Browse pgsql-hackers by date

  From Date Subject
Next Message Andrew Gierth 2018-07-02 18:23:25 Re: Should contrib modules install .h files?
Previous Message Robert Haas 2018-07-02 18:18:41 Re: alter index WITH ( storage_parameter = value [, ... ] ) for partition index.