Re: Strange random() Correlation
От | Tom Lane |
---|---|
Тема | Re: Strange random() Correlation |
Дата | |
Msg-id | 23553.1148745033@sss.pgh.pa.us обсуждение исходный текст |
Ответ на | Strange random() Correlation (Volkan YAZICI <yazicivo@ttnet.net.tr>) |
Ответы |
Re: Strange random() Correlation
|
Список | pgsql-bugs |
Volkan YAZICI <yazicivo@ttnet.net.tr> writes: > ISTM, there's a problem in the correlation of random() to outer JOINs. The random() functions are being evaluated more than once because the subselect gets "flattened" into the outer query, so that you have the equivalent of select random(), ... where t2.id = random() ... We've previously discussed preventing the planner from flattening if there are any volatile functions in the sub-select's output list, but I think that would probably do about as much harm as good. The cases where this actually matters are rare and the programmer knows darn well what he's doing, so the workaround of inserting an OFFSET 0 to prevent the flattening seems acceptable to me. > Furthermore, if you'd append an "OFFSET 0" to subselect, output becomes > more stable but still has some inconsistencies. I didn't see any... regards, tom lane
В списке pgsql-bugs по дате отправления: