Dept of second thoughts: the IQ of estimate_array_length() needs to be
kept on par with that of scalararraysel(), else estimates that should track might not. Hence teach it about binary-compatible cases, too.
This commit is contained in:
parent
c2c0b318d8
commit
a053437d9e
@ -15,7 +15,7 @@
|
|||||||
*
|
*
|
||||||
*
|
*
|
||||||
* IDENTIFICATION
|
* IDENTIFICATION
|
||||||
* $PostgreSQL: pgsql/src/backend/utils/adt/selfuncs.c,v 1.222 2007/01/28 01:37:38 tgl Exp $
|
* $PostgreSQL: pgsql/src/backend/utils/adt/selfuncs.c,v 1.223 2007/01/28 02:53:34 tgl Exp $
|
||||||
*
|
*
|
||||||
*-------------------------------------------------------------------------
|
*-------------------------------------------------------------------------
|
||||||
*/
|
*/
|
||||||
@ -1698,6 +1698,9 @@ scalararraysel(PlannerInfo *root,
|
|||||||
int
|
int
|
||||||
estimate_array_length(Node *arrayexpr)
|
estimate_array_length(Node *arrayexpr)
|
||||||
{
|
{
|
||||||
|
/* look through any binary-compatible relabeling of arrayexpr */
|
||||||
|
arrayexpr = strip_array_coercion(arrayexpr);
|
||||||
|
|
||||||
if (arrayexpr && IsA(arrayexpr, Const))
|
if (arrayexpr && IsA(arrayexpr, Const))
|
||||||
{
|
{
|
||||||
Datum arraydatum = ((Const *) arrayexpr)->constvalue;
|
Datum arraydatum = ((Const *) arrayexpr)->constvalue;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user