From: | Pavel Stehule <pavel(dot)stehule(at)gmail(dot)com> |
---|---|
To: | Dmitry Dolgov <9erthalion6(at)gmail(dot)com> |
Cc: | Justin Pryzby <pryzby(at)telsasoft(dot)com>, Tom Lane <tgl(at)sss(dot)pgh(dot)pa(dot)us>, David Steele <david(at)pgmasters(dot)net>, Nikita Glukhov <n(dot)gluhov(at)postgrespro(dot)ru>, Alvaro Herrera <alvherre(at)2ndquadrant(dot)com>, David Fetter <david(at)fetter(dot)org>, Thomas Munro <thomas(dot)munro(at)gmail(dot)com>, Thomas Munro <thomas(dot)munro(at)enterprisedb(dot)com>, Oleksandr Shulgin <oleksandr(dot)shulgin(at)zalando(dot)de>, Robert Haas <robertmhaas(at)gmail(dot)com>, Andres Freund <andres(at)anarazel(dot)de>, Michael Paquier <michael(dot)paquier(at)gmail(dot)com>, Oleg Bartunov <obartunov(at)gmail(dot)com>, Peter Eisentraut <peter(dot)eisentraut(at)2ndquadrant(dot)com>, PostgreSQL Hackers <pgsql-hackers(at)postgresql(dot)org> |
Subject: | Re: [HACKERS] [PATCH] Generic type subscripting |
Date: | 2020-09-17 15:19:19 |
Message-ID: | CAFj8pRAQS3Z_ViOmMKCHWTu2uzajCuUUWwxq3z2nWpRWE1D3tg@mail.gmail.com |
Views: | Raw Message | Whole Thread | Download mbox | Resend email |
Thread: | |
Lists: | pgsql-hackers |
čt 17. 9. 2020 v 15:56 odesílatel Dmitry Dolgov <9erthalion6(at)gmail(dot)com>
napsal:
> > On Thu, Sep 17, 2020 at 02:47:54PM +0200, Pavel Stehule wrote:
> > > I have my concerns about the performance side of this implementation as
> > > well as how surprising this would be for users, but at the same time
> the
> > > patch already does something similar and the code change should not be
> > > that big, so why not - I can include this change into the next rebased
> > > version. But it still can cause some confusion as it's not going to
> work
> > > for negative indices, so
> > >
> > > update foo set a[-10] = 1;
> > >
> > > and
> > >
> > > select a[-10] from foo;
> > >
> > > can return different value from what was assigned. Otherwise, if we
> will
> > > try to fix a[-10] assignment in the same way, it will prepend the array
> > > and a[10] will not return the same value.
> >
> > What is semantic of negative index? It has clean semantic in C, but in
> > PLpgSQL?
>
> It's just a common pattern for jsonb when a negative index count from
> the end of an array. I believe it was like that from the very earlier
> implementations, although can't comment on that from the semantic point
> of view.
>
ok, then I think we can design some workable behaviour
My first rule - there should not be any implicit action that shifts
positions in the array. It can be explicit, but not implicit. It is true
for positive indexes, and it should be true for negative indexes too.
then I think so some like this can work
if (idx < 0)
{
if (abs(idx) > length of array)
exception("index is of of range");
array[length of array - idx] := value;
}
else
{
/* known behave for positive index */
}
Regards
Pavel
From | Date | Subject | |
---|---|---|---|
Next Message | Tom Lane | 2020-09-17 15:39:56 | Re: pgindent vs dtrace on macos |
Previous Message | Juan José Santamaría Flecha | 2020-09-17 15:16:15 | Re: BUG #15858: could not stat file - over 4GB |