Re: BUG #18965: Issue with Short-Circuit Evaluation in Boolean Expressions - Mailing list pgsql-bugs

From Jeff Davis
Subject Re: BUG #18965: Issue with Short-Circuit Evaluation in Boolean Expressions
Date
Msg-id 33ae625c9ec9072ac61708405c2e7dfe50097047.camel@j-davis.com
Whole thread Raw
In response to Re: BUG #18965: Issue with Short-Circuit Evaluation in Boolean Expressions  ("David G. Johnston" <david.g.johnston@gmail.com>)
List pgsql-bugs
On Fri, 2025-06-20 at 11:14 -0700, David G. Johnston wrote:
> > In the circumstance where a function evaluation is performed within
> > Boolean
> > expression, the evaluation seems to continue past a function
> > returning a
> > TRUE value.
> >
>
> Where did we claim we perform short-circuiting?

Even if you force the execution-time evaluation order with CASE, you
can still get an error:

EXPLAIN SELECT CASE WHEN random() < 2 THEN TRUE ELSE (1/0 = 0) END;
ERROR:  division by zero

The expression "random() < 2" is always true, so at execution time the
second branch will never be reached. But it is reached at planning
time.

Regards,
    Jeff Davis




pgsql-bugs by date:

Previous
From: Laurenz Albe
Date:
Subject: Re: Unexpected behavior when setting "idle_replication_slot_timeout"
Next
From: Jeff Davis
Date:
Subject: Re: BUG #18965: Issue with Short-Circuit Evaluation in Boolean Expressions