| От | Tom Lane |
|---|---|
| Тема | Re: [GENERAL] Unexpected interval comparison |
| Дата | |
| Msg-id | 30765.1490107336@sss.pgh.pa.us обсуждение исходный текст |
| Ответ на | [GENERAL] Unexpected interval comparison (Frazer McLean <frazer@frazermclean.co.uk>) |
| Ответы |
Re: [GENERAL] Unexpected interval comparison
|
| Список | pgsql-general |
Frazer McLean <frazer@frazermclean.co.uk> writes:
> I came across an unexpected comparison (tested on PostgreSQL 9.4 and
> 9.6) for intervals with a large difference in magnitude.
> '1 year'::interval > '32618665 years'::interval;
> Is this a bug?
It looks like the problem is overflow of the result of interval_cmp_value,
because it's trying to compute
=# select '32618665'::int8 * 30 * 86400 * 1000000;
ERROR: bigint out of range
It's not immediately obvious how to avoid that while preserving the same
comparison semantics :-(
regards, tom lane
В списке pgsql-general по дате отправления:
Сайт использует файлы cookie для корректной работы и повышения удобства. Нажимая кнопку «Принять» или продолжая пользоваться сайтом, вы соглашаетесь на их использование в соответствии с Политикой в отношении обработки cookie ООО «ППГ», в том числе на передачу данных из файлов cookie сторонним статистическим и рекламным службам. Вы можете управлять настройками cookie через параметры вашего браузера