Re: functions allowed in CHECK constraints - Mailing list pgsql-sql

From Tom Lane
Subject Re: functions allowed in CHECK constraints
Date
Msg-id 1002.1518186736@sss.pgh.pa.us
Whole thread Raw
In response to Re: functions allowed in CHECK constraints  ("David G. Johnston" <david.g.johnston@gmail.com>)
List pgsql-sql
"David G. Johnston" <david.g.johnston@gmail.com> writes:
> On Fri, Feb 9, 2018 at 1:37 AM, Achilleas Mantzios <
> itdev@itdevel.internal.net> wrote:
>> So, what's the point in forbidding the use of subselects if one can use
>> functions? And OTOH if effectively doing so is bad for some reason, why let
>> it happen with a function?

> Short answer, the system treats the function as a black-box and doesn't
> know that you've used it to circumvent its prohibition on subselects.  The
> prohibition still is in place though.  If you use a function you are
> expected to ensure you do not violate any of the restrictions yourself.

Actually, I'd say that the possibility to use a function is a workaround
for the fact that you can't write a sub-select directly ;-).  The latter
is more of an implementation restriction than anything else, stemming
from the fact that we don't run CHECK expressions through the planner.

Now, it's certainly true that you can use a sub-select to write a
non-immutable CHECK expression and thereby shoot yourself in the foot.
But you can shoot yourself in the foot that way without sub-selects,
too.  We do not try to enforce that CHECK expressions are immutable.

            regards, tom lane


pgsql-sql by date:

Previous
From: "David G. Johnston"
Date:
Subject: Re: functions allowed in CHECK constraints
Next
From: Lahari Sengupta
Date:
Subject: Conditional update