Re: [sqlsmith] Crash in mcv_get_match_bitmap
| От | Tom Lane |
|---|---|
| Тема | Re: [sqlsmith] Crash in mcv_get_match_bitmap |
| Дата | |
| Msg-id | 17042.1562795124@sss.pgh.pa.us обсуждение исходный текст |
| Ответ на | Re: [sqlsmith] Crash in mcv_get_match_bitmap (Tomas Vondra <tomas.vondra@2ndquadrant.com>) |
| Ответы |
Re: [sqlsmith] Crash in mcv_get_match_bitmap
|
| Список | pgsql-hackers |
Tomas Vondra <tomas.vondra@2ndquadrant.com> writes:
> Yeah, that's a bug. Will fix (not sure how yet).
You could do worse than replace this:
ok = (NumRelids(clause) == 1) &&
(is_pseudo_constant_clause(lsecond(expr->args)) ||
(varonleft = false,
is_pseudo_constant_clause(linitial(expr->args))));
with something like
if (IsA(linitial(expr->args), Var) &&
IsA(lsecond(expr->args), Const))
ok = true, varonleft = true;
else if (IsA(linitial(expr->args), Const) &&
IsA(lsecond(expr->args), Var))
ok = true, varonleft = false;
Or possibly get rid of varonleft as such, and merge extraction of the
"var" and "cst" variables into this test.
BTW, I bet passing a unary-argument OpExpr also makes this code
unhappy.
regards, tom lane
В списке pgsql-hackers по дате отправления: