Re: order of adding date & interval values?

Поиск
Список
Период
Сортировка
От Thomas Lockhart
Тема Re: order of adding date & interval values?
Дата
Msg-id 3CD1F408.D95FCDB1@fourpalms.org
обсуждение исходный текст
Ответ на order of adding date & interval values?  (Lev Lvovsky <lists1@sonous.com>)
Список pgsql-general
> is there any reason why the order of operations of the following query
> would matter?

Yes. But not a good one :(

> diw=# select interval '40 years' +  date '2001-01-01' as test;
> ---------------------
>  2001-01-01 00:00:00

This is relying on the interval being turned into a time field, which
gets modulo'd by 24 hours. We should probably check the conversion and
reject anything which needs modulo to fit into 24 hours, and we should
probably not allow this particular implicit coersion by defining an
explicit operator for these two data types in this order.

We used to have the ability to reorder the arithmetic to get the correct
answer, but afaicr that was removed since we were apparently misusing
fields to accomplish this.

> also, is there a difference between:
> "interval('40 years') " and "interval '40 years' " ?
> or
> "date('2001-01-01')" and "date '2001-01-01' " ?
> diw=# select date('2001-01-01') + interval('40 years') as test;
> ERROR:  parser: parse error at or near "'"

In 7.2.x, interval(int) is the specifier for a data type, not a function
call. The same new feature is available for timestamp. So you can't use
the function call form for type conversion anymore (at least not without
gymnastics). Use

interval '40 years'

instead.

                     - Thomas

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

Предыдущее
От: Tom Lane
Дата:
Сообщение: Re: select from function
Следующее
От: Tom Lane
Дата:
Сообщение: Re: order of adding date & interval values?