From: | Tom Lane <tgl(at)sss(dot)pgh(dot)pa(dot)us> |
---|---|
To: | Jan Wieck <JanWieck(at)Yahoo(dot)com> |
Cc: | pgsql-hackers(at)postgresql(dot)org |
Subject: | Re: [SQL] plpgsql doesn't coerce boolean expressions to boolean |
Date: | 2003-09-28 01:28:33 |
Message-ID: | 3487.1064712513@sss.pgh.pa.us |
Views: | Raw Message | Whole Thread | Download mbox | Resend email |
Thread: | |
Lists: | pgsql-hackers pgsql-sql |
Jan Wieck <JanWieck(at)Yahoo(dot)com> writes:
> Tom Lane wrote:
>>> 4. Use the parser's coerce_to_boolean procedure, so that nonbooleans
>>> will be accepted in exactly the same cases where they'd be accepted
>>> in a boolean-requiring SQL construct (such as CASE). (By default,
>>> none are, so this isn't really different from #2. But people could
>>> create casts to boolean to override this behavior in a controlled
>>> fashion.)
> Agreed - #4.
My first attempt at doing this failed to pass the regression tests,
because it wasn't prepared for this:
if count(*) = 0 from Room where roomno = new.roomno then
raise exception ''Room % does not exist'', new.roomno;
end if;
Is this really intended to be a feature? It manages to work because
plpgsql simply sticks "SELECT " in front of whatever appears between
IF and THEN, and passes the result to the main SQL engine. But it sure
surprised the heck out of me. The documentation gives no hint that
you're allowed to write anything but a straight boolean expression in IF.
Does Oracle allow that sort of thing?
I would be inclined to think that a more reasonable expression of the
intent would be
if (select count(*) from Room where roomno = new.roomno) = 0 then
Certainly we'd have a big problem supporting the existing coding if we
ever reimplement plpgsql with more awareness of what expressions are.
regards, tom lane
From | Date | Subject | |
---|---|---|---|
Next Message | Tom Lane | 2003-09-28 01:35:42 | Re: [COMMITTERS] pgsql-server/src/backend/executor execScan.c |
Previous Message | Bruce Momjian | 2003-09-28 01:20:06 | Re: Problem with function permission test in a view |
From | Date | Subject | |
---|---|---|---|
Next Message | Bertrand Petit | 2003-09-28 01:53:13 | Re: pg_class.relpages |
Previous Message | Tom Lane | 2003-09-28 00:31:45 | Re: pg_class.relpages |