Re: BUG #18904: INTERSECT with an impossible where should eliminateboth from the query plan
От | Jinhui Lai |
---|---|
Тема | Re: BUG #18904: INTERSECT with an impossible where should eliminateboth from the query plan |
Дата | |
Msg-id | tencent_F22C20E3310DEC4D88B1BA086FD1DA5DFF0A@qq.com обсуждение исходный текст |
Ответ на | Re: BUG #18904: INTERSECT with an impossible where should eliminate both from the query plan (David Rowley <dgrowleyml@gmail.com>) |
Ответы |
Re: BUG #18904: INTERSECT with an impossible where should eliminateboth from the query plan
|
Список | pgsql-bugs |
Dear PostgreSQL Developer,
My point is that this kind of query, which is always logically empty, should not be executed at all. Executing it not only wastes time, but more concerningly, it can lead to incorrect results. I have discovered bugs in MySQL, MariaDB, and TiDB where such queries, which should have returned empty result sets, instead produced incorrect non-empty results due to being actually executed. Since I’ve only recently started working with PostgreSQL in the past two days, I haven’t yet tested whether it exhibits similar bugs. If I do find any such cases, I will provide concrete examples. Therefore, my additional point is that avoiding the execution of such queries can fundamentally eliminate these types of logical bugs at their source.
Best regrerds,
Best regrerds,
原始邮件
发件人:David Rowley <dgrowleyml@gmail.com> 发件时间:2025年4月29日 19:57 收件人:Tom Lane <tgl@sss.pgh.pa.us> 抄送:David G. Johnston <david.g.johnston@gmail.com>, jh.lai@qq.com <jh.lai@qq.com>, pgsql-bugs@lists.postgresql.org <pgsql-bugs@lists.postgresql.org> 主题:Re: BUG #18904: INTERSECT with an impossible where should eliminateboth from the query plan |
> Anyway, as David said, this is not a bug. If it's something you
> really want to see happen, try writing a patch yourself.
This is already somewhat better in v18 thanks to [1].
generate_nonunion_paths() already has some code to put the smallest
child on the left, and the recent changes in nodeSetOp.c means very
little work will be done when the left side is empty.
David
[1] https://git.postgresql.org/gitweb/?p=postgresql.git;a=commit;h=276279295
В списке pgsql-bugs по дате отправления: