| From: | Tom Lane <tgl(at)sss(dot)pgh(dot)pa(dot)us> |
|---|---|
| To: | bajinsheng(at)u(dot)nus(dot)edu |
| Cc: | pgsql-bugs(at)lists(dot)postgresql(dot)org |
| Subject: | Re: BUG #18222: Unexpected Error--Cannot delete from scalar |
| Date: | 2023-12-04 14:15:46 |
| Message-ID: | 751502.1701699346@sss.pgh.pa.us |
| Views: | Whole Thread | Raw Message | Download mbox | Resend email |
| Thread: | |
| Lists: | pgsql-bugs |
PG Bug reporting form <noreply(at)postgresql(dot)org> writes:
> SELECT ('1'-to_hex(2))::BOOLEAN; -- ERROR: cannot delete from scalar
> This error looks strange to me as I do not understand what this error
> means.
Just out of curiosity, what did you expect that to do?
to_hex() produces type text, and there's no "text - text" operator.
What's evidently happening is that the parser finds "jsonb - text"
(i.e., jsonb_delete) as the only potentially applicable operator.
It successfully coerces '1' to a scalar jsonb value, but then
jsonb_delete() spits up because it's expecting an array.
I'm not sure that it was such a great idea to define '-' as having
this meaning for jsonb, but it's been there awhile now so probably
too late to change.
regards, tom lane
| From | Date | Subject | |
|---|---|---|---|
| Next Message | Tom Lane | 2023-12-04 14:18:12 | Re: BUG #18224: message bug in libpqwalreceiver.c. |
| Previous Message | Daniel Gustafsson | 2023-12-04 14:10:02 | Re: BUG #18224: message bug in libpqwalreceiver.c. |