Re: Parameter types are inferred from context of first use only.

From: Bruce Momjian <bruce(at)momjian(dot)us>
To: Morgan Owens <packrat(at)varteg(dot)nz>
Cc: Nick Farmer <farmernick-pg(at)varteg(dot)nz>, pgsql-docs(at)lists(dot)postgresql(dot)org
Subject: Re: Parameter types are inferred from context of first use only.
Date: 2018-08-09 14:14:33
Message-ID: 20180809141433.GA2876@momjian.us
Views: Raw Message | Whole Thread | Download mbox | Resend email
Thread:
Lists: pgsql-docs

On Thu, Aug 9, 2018 at 12:18:27PM +1200, Morgan Owens wrote:
> On 2018-08-09 05:24, Bruce Momjian wrote:
> >On Mon, Jul 23, 2018 at 09:14:48AM +0000, PG Doc comments form wrote:
> >>The following documentation comment has been logged on the website:
> >>
> >>Page: https://www.postgresql.org/docs/10/static/sql-prepare.html
> >>Description:
> >>
> >>Background can be found on the bugs list (pgsql-bug #15289). It was
> >>explained that when a prepared statement parameter needs to have its type
> >>inferred then, should the parameter be used more than once, only the first
> >>use is considered. (The example in that report is that the type of $1 can be
> >>inferred from "($1 = col) or ($1 is null)" but not from "($1 is null) or ($1
> >>= col)".)
> >>
> >>The documentation as it stands says only that the parameter's type is
> >>inferred from the context in which it is used. The "first use only" proviso
> >>is not mentioned (hence "context" isn't so broad as to consist of all of the
> >>expressions in which the parameter appears).
> >
> >I have developed the attached patch to cover what you found.
> >
>
> That says it for me. The third mention of context doesn't need anything
> because it's referring specifically to the (single) use of $2 in the
> example. I have to presume the type inference happens before any structural
> changes that might change the meaning of "first occurrence".

Great, patch applied through 9.3. I also changed "used" to
"referenced":

https://git.postgresql.org/pg/commitdiff/b284262e40424daa1c546ad76f365b31304d7944

--
Bruce Momjian <bruce(at)momjian(dot)us> http://momjian.us
EnterpriseDB http://enterprisedb.com

+ As you are, so once was I. As I am, so you will be. +
+ Ancient Roman grave inscription +

In response to

Responses

Browse pgsql-docs by date

  From Date Subject
Next Message Bruce Momjian 2018-08-09 14:15:27 Re: Parameter types are inferred from context of first use only.
Previous Message KES 2018-08-09 10:11:05 Re: Typo in doc or wrong EXCLUDE implementation