Re: [HACKERS] Bug in to_timestamp().
| От | Arthur Zakirov | 
|---|---|
| Тема | Re: [HACKERS] Bug in to_timestamp(). | 
| Дата | |
| Msg-id | 20180112125848.GA32559@zakirov.localdomain обсуждение исходный текст | 
| Ответ на | Re: [HACKERS] Bug in to_timestamp(). (Thomas Munro <thomas.munro@enterprisedb.com>) | 
| Ответы | Re: [HACKERS] Bug in to_timestamp(). | 
| Список | pgsql-hackers | 
Hello,
On Fri, Jan 12, 2018 at 02:48:40PM +1300, Thomas Munro wrote:
> 
> I'm guessing that commit 11b623dd0a2c385719ebbbdd42dd4ec395dcdc9d had
> something to do with the following failure, when your patch is
> applied:
> 
>      horology                 ... FAILED
> 
Thank you a lot for pointing on that.
It seems to me that it happens because the patch eats minus sign "-" before "05". And it is wrong to do that.
I attached new version of the patch. Now (expected output):
=# SELECT to_timestamp('2011-12-18 11:38 -05', 'YYYY-MM-DD HH12:MI TZH');
      to_timestamp      
------------------------
 2011-12-18 20:38:00+04
But these queries may confuse:
=# SELECT to_timestamp('2011-12-18 11:38 -05', 'YYYY-MM-DD HH12:MI  TZH');
      to_timestamp      
------------------------
 2011-12-18 10:38:00+04
=# SELECT to_timestamp('2011-12-18 11:38 -05', 'YYYY-MM-DD HH12:MI -TZH');
      to_timestamp      
------------------------
 2011-12-18 10:38:00+04
And these queries don't work anymore using new version of the patch:
=# SELECT to_timestamp('2000 + JUN', 'YYYY MON');
ERROR:  invalid value "+ J" for "MON"
DETAIL:  The given value did not match any of the allowed values for this field.
=# SELECT to_timestamp('2000 +   JUN', 'YYYY MON');
ERROR:  invalid value "+  " for "MON"
DETAIL:  The given value did not match any of the allowed values for this field.
Other queries mentioned in the thread work as before.
Any thoughts? If someone has better approach, feel free to share it.
-- 
Arthur Zakirov
Postgres Professional: http://www.postgrespro.com
Russian Postgres Company
		
	Вложения
В списке pgsql-hackers по дате отправления: