Re: Weird NULL behavior

Поиск
Список
Период
Сортировка
От Tom Lane
Тема Re: Weird NULL behavior
Дата
Msg-id 28164.1036696164@sss.pgh.pa.us
обсуждение исходный текст
Ответ на Re: Weird NULL behavior  (Stephan Szabo <sszabo@megazone23.bigpanda.com>)
Ответы Re: Weird NULL behavior  (Stephan Szabo <sszabo@megazone23.bigpanda.com>)
Список pgsql-sql
Stephan Szabo <sszabo@megazone23.bigpanda.com> writes:
> On Thu, 7 Nov 2002, Ludwig Lim wrote:
>> SELECT CAST ( (NULL*NULL) AS NUMERIC(2,0));
>> Cannot cast type '"char"' to '"numeric"'

> It seems to me that it's trying to decide on a type
> for the expression NULL * NULL.  It's a NULL, but a
> NULL of what type?

Yeah, and it's picking "char" (the single-byte datatype), because
(a) the NULLs are initially regarded as type UNKNOWN, and (b) if we
don't have any other way to make a decision we try assuming that
UNKNOWNs are of string category, and (c) the only datatype in string
category that has a "*" operator is "char".

I am kind of inclined to remove the arithmetic operators on "char"
(+,-,*,/) in 7.4 --- they don't seem to have any real-world uses,
and as this example illustrates, they are perfectly positioned to
capture cases that probably ought to be errors.

But as you say, the proper solution for Ludwig's problem is to cast the
NULLs themselves to numeric, not the result of the multiplication.
        regards, tom lane


В списке pgsql-sql по дате отправления:

Предыдущее
От: Jeff Boes
Дата:
Сообщение: Quartile (etc) ranking in a SQL statement?
Следующее
От: Stephan Szabo
Дата:
Сообщение: Re: Weird NULL behavior