Re: Validity check in to_date?
От | Karel Zak |
---|---|
Тема | Re: Validity check in to_date? |
Дата | |
Msg-id | 20031202095713.GB17884@zf.jcu.cz обсуждение исходный текст |
Ответ на | Re: Validity check in to_date? (Christoph Haller <ch@rodos.fzk.de>) |
Ответы |
Re: Validity check in to_date?
|
Список | pgsql-sql |
On Tue, Dec 02, 2003 at 10:27:04AM +0100, Christoph Haller wrote: > > > > I just discovered that to_date() function does not check if supplied > > date is correct, giving surprising (at least for me) results: > > > > fduch=# SELECT to_date('31.11.2003', 'DD.MM.YYYY'); > > to_date > > ------------ > > 2003-12-01 > > > > or even > > > > fduch=# SELECT to_date('123.45.2003', 'DD.MM.YYYY'); > > to_date > > ------------ > > 2007-01-03 > > > > to_timestamp() seems to work the same way. It's probably useful sometimes, > > but not in my case... Is it how it supposed to work? > > If so, how can I do such a validity check? > > If not, has something changed in 7.4? No change in 7.4. Maybe in 7.5 or in some 7.4.x. > As far as I know these results are correct in terms of the underlying > C-library function mktime(). This function is intended to be used when > adding/subtracting intervals from a given timestamp. > I don't know of any postgres function doing the check you're looking for. > But I can't believe this is the first time this topic is brought up. > You may search the archives on "date plausibility" are related terms. The others PostgreSQL stuff which full parse (means check ranges)date/time is less optimistic with this: # select '31.11.2003'::date;ERROR: date/time field value out of range: "31.11.2003" Karel -- Karel Zak <zakkr@zf.jcu.cz>http://home.zf.jcu.cz/~zakkr/
В списке pgsql-sql по дате отправления: