Re: Inaccurate description of UNION/CASE/etc type selection - Mailing list pgsql-docs
From | Tom Lane |
---|---|
Subject | Re: Inaccurate description of UNION/CASE/etc type selection |
Date | |
Msg-id | 1077763.1597684264@sss.pgh.pa.us Whole thread Raw |
In response to | Re: Inaccurate description of UNION/CASE/etc type selection ("David G. Johnston" <david.g.johnston@gmail.com>) |
Responses |
Re: Inaccurate description of UNION/CASE/etc type selection
|
List | pgsql-docs |
"David G. Johnston" <david.g.johnston@gmail.com> writes: > On Mon, Aug 17, 2020 at 8:31 AM Tom Lane <tgl@sss.pgh.pa.us> wrote: >> So this is just a verbatim statement of the algorithm, which is what >> I was hoping to avoid :-(. But maybe there's no simpler way. > I got nothin'. Yeah, me either. So here's a proposed patch, fixing a couple other things: * Re-reading this, I thought the use of "preferred" in the existing footnote about domains could be read as meaning that we treat the base type as a preferred type; so I changed that. * Something that's been true for a very long time, but never documented, is that CASE puts its ELSE clause at the front for this purpose. I figured that if we're trying to tell the full truth we better mention that. regards, tom lane diff --git a/doc/src/sgml/typeconv.sgml b/doc/src/sgml/typeconv.sgml index 81dba7dacf..8900d0eb38 100644 --- a/doc/src/sgml/typeconv.sgml +++ b/doc/src/sgml/typeconv.sgml @@ -1069,7 +1069,7 @@ domain's base type for all subsequent steps. functions, this behavior allows a domain type to be preserved through a <literal>UNION</literal> or similar construct, so long as the user is careful to ensure that all inputs are implicitly or explicitly of that - exact type. Otherwise the domain's base type will be preferred. + exact type. Otherwise the domain's base type will be used. </para> </footnote> </para> @@ -1092,24 +1092,29 @@ If the non-unknown inputs are not all of the same type category, fail. <step performance="required"> <para> -Choose the first non-unknown input type which is a preferred type in -that category, if there is one. -</para> -</step> - -<step performance="required"> -<para> -Otherwise, choose the last non-unknown input type that allows all the -preceding non-unknown inputs to be implicitly converted to it. (There -always is such a type, since at least the first type in the list must -satisfy this condition.) +Select the first non-unknown input type as the candidate type, +then consider each other non-unknown input type, left to right. + <footnote> + <para> + For historical reasons, <literal>CASE</literal> treats + its <literal>ELSE</literal> clause (if any) as the <quote>first</quote> + input, with the <literal>THEN</literal> clauses(s) considered after + that. In all other cases, <quote>left to right</quote> means the order + in which the expressions appear in the query text. + </para> + </footnote> +If the candidate type can be implicitly converted to the other type, +but not vice-versa, select the other type as the new candidate type. +Then continue considering the remaining inputs. If, at any stage of this +process, a preferred type is selected, stop considering additional +inputs. </para> </step> <step performance="required"> <para> -Convert all inputs to the selected type. Fail if there is not a -conversion from a given input to the selected type. +Convert all inputs to the final candidate type. Fail if there is not an +implicit conversion from a given input type to the candidate type. </para> </step> </procedure>
pgsql-docs by date: