2000-01-05 07:07:58 +01:00
|
|
|
--
|
|
|
|
-- ABSTIME
|
|
|
|
-- testing built-in time type abstime
|
|
|
|
-- uses reltime and tinterval
|
|
|
|
--
|
1997-04-05 13:08:30 +02:00
|
|
|
|
|
|
|
--
|
|
|
|
-- timezones may vary based not only on location but the operating
|
|
|
|
-- system. the main correctness issue is that the OS may not get
|
1997-04-27 04:58:38 +02:00
|
|
|
-- daylight savings time right for times prior to Unix epoch (jan 1 1970).
|
1997-04-05 13:08:30 +02:00
|
|
|
--
|
|
|
|
|
|
|
|
CREATE TABLE ABSTIME_TBL (f1 abstime);
|
|
|
|
|
|
|
|
INSERT INTO ABSTIME_TBL (f1) VALUES ('Jan 14, 1973 03:14:21');
|
|
|
|
|
2000-01-05 07:07:58 +01:00
|
|
|
-- was INSERT INTO ABSTIME_TBL (f1) VALUES (abstime 'now'):
|
|
|
|
INSERT INTO ABSTIME_TBL (f1) VALUES (abstime 'Mon May 1 00:30:30 1995');
|
1997-04-05 13:08:30 +02:00
|
|
|
|
2000-01-05 07:07:58 +01:00
|
|
|
INSERT INTO ABSTIME_TBL (f1) VALUES (abstime 'epoch');
|
1997-04-05 13:08:30 +02:00
|
|
|
|
2000-01-05 07:07:58 +01:00
|
|
|
INSERT INTO ABSTIME_TBL (f1) VALUES (abstime 'current');
|
1997-04-05 13:08:30 +02:00
|
|
|
|
2000-01-05 07:07:58 +01:00
|
|
|
INSERT INTO ABSTIME_TBL (f1) VALUES (abstime 'infinity');
|
1997-04-05 13:08:30 +02:00
|
|
|
|
2000-01-05 07:07:58 +01:00
|
|
|
INSERT INTO ABSTIME_TBL (f1) VALUES (abstime '-infinity');
|
1997-04-05 13:08:30 +02:00
|
|
|
|
2000-01-05 07:07:58 +01:00
|
|
|
INSERT INTO ABSTIME_TBL (f1) VALUES (abstime 'May 10, 1947 23:59:12');
|
1997-04-05 13:08:30 +02:00
|
|
|
|
|
|
|
|
|
|
|
-- what happens if we specify slightly misformatted abstime?
|
|
|
|
INSERT INTO ABSTIME_TBL (f1) VALUES ('Feb 35, 1946 10:00:00');
|
|
|
|
|
|
|
|
INSERT INTO ABSTIME_TBL (f1) VALUES ('Feb 28, 1984 25:08:10');
|
|
|
|
|
|
|
|
|
|
|
|
-- badly formatted abstimes: these should result in invalid abstimes
|
|
|
|
INSERT INTO ABSTIME_TBL (f1) VALUES ('bad date format');
|
|
|
|
|
|
|
|
INSERT INTO ABSTIME_TBL (f1) VALUES ('Jun 10, 1843');
|
|
|
|
|
|
|
|
-- test abstime operators
|
|
|
|
|
1997-04-27 04:58:38 +02:00
|
|
|
SELECT '' AS eight, ABSTIME_TBL.*;
|
1997-04-05 13:08:30 +02:00
|
|
|
|
1997-04-27 04:58:38 +02:00
|
|
|
SELECT '' AS six, ABSTIME_TBL.*
|
2000-01-05 07:07:58 +01:00
|
|
|
WHERE ABSTIME_TBL.f1 < abstime 'Jun 30, 2001';
|
1997-04-05 13:08:30 +02:00
|
|
|
|
1997-04-27 04:58:38 +02:00
|
|
|
SELECT '' AS six, ABSTIME_TBL.*
|
2000-01-05 07:07:58 +01:00
|
|
|
WHERE ABSTIME_TBL.f1 > abstime '-infinity';
|
1997-04-05 13:08:30 +02:00
|
|
|
|
1997-04-27 04:58:38 +02:00
|
|
|
SELECT '' AS six, ABSTIME_TBL.*
|
2000-01-05 07:07:58 +01:00
|
|
|
WHERE abstime 'May 10, 1947 23:59:12' <> ABSTIME_TBL.f1;
|
1997-04-05 13:08:30 +02:00
|
|
|
|
|
|
|
SELECT '' AS one, ABSTIME_TBL.*
|
2000-01-05 07:07:58 +01:00
|
|
|
WHERE abstime 'current' = ABSTIME_TBL.f1;
|
1997-04-05 13:08:30 +02:00
|
|
|
|
1997-04-27 04:58:38 +02:00
|
|
|
SELECT '' AS three, ABSTIME_TBL.*
|
2000-01-05 07:07:58 +01:00
|
|
|
WHERE abstime 'epoch' >= ABSTIME_TBL.f1;
|
1997-04-05 13:08:30 +02:00
|
|
|
|
1997-04-27 04:58:38 +02:00
|
|
|
SELECT '' AS four, ABSTIME_TBL.*
|
2000-01-05 07:07:58 +01:00
|
|
|
WHERE ABSTIME_TBL.f1 <= abstime 'Jan 14, 1973 03:14:21';
|
1997-04-05 13:08:30 +02:00
|
|
|
|
1997-04-27 04:58:38 +02:00
|
|
|
SELECT '' AS four, ABSTIME_TBL.*
|
1997-04-05 13:08:30 +02:00
|
|
|
WHERE ABSTIME_TBL.f1 <?>
|
2000-01-05 07:07:58 +01:00
|
|
|
tinterval '["Apr 1 1950 00:00:00" "Dec 30 1999 23:00:00"]';
|
1997-04-05 13:08:30 +02:00
|
|
|
|
|
|
|
-- these four queries should return the same answer
|
|
|
|
-- the "infinity" and "-infinity" tuples in ABSTIME_TBL cannot be added and
|
|
|
|
-- therefore, should not show up in the results.
|
1997-04-27 04:58:38 +02:00
|
|
|
SELECT '' AS three, ABSTIME_TBL.*
|
2000-01-05 07:07:58 +01:00
|
|
|
WHERE (ABSTIME_TBL.f1 + reltime '@ 3 year') -- +3 years
|
|
|
|
< abstime 'Jan 14 14:00:00 1977';
|
1997-04-05 13:08:30 +02:00
|
|
|
|
1997-04-27 04:58:38 +02:00
|
|
|
SELECT '' AS three, ABSTIME_TBL.*
|
2000-01-05 07:07:58 +01:00
|
|
|
WHERE (ABSTIME_TBL.f1 + reltime '@ 3 year ago') -- -3 years
|
|
|
|
< abstime 'Jan 14 14:00:00 1971';
|
1997-04-05 13:08:30 +02:00
|
|
|
|
1997-04-27 04:58:38 +02:00
|
|
|
SELECT '' AS three, ABSTIME_TBL.*
|
2000-01-05 07:07:58 +01:00
|
|
|
WHERE (ABSTIME_TBL.f1 - reltime '@ 3 year') -- -(+3) years
|
|
|
|
< abstime 'Jan 14 14:00:00 1971';
|
1997-04-05 13:08:30 +02:00
|
|
|
|
1997-04-27 04:58:38 +02:00
|
|
|
SELECT '' AS three, ABSTIME_TBL.*
|
2000-01-05 07:07:58 +01:00
|
|
|
WHERE (ABSTIME_TBL.f1 - reltime '@ 3 year ago') -- -(-3) years
|
|
|
|
< abstime 'Jan 14 14:00:00 1977';
|
1997-04-05 13:08:30 +02:00
|
|
|
|
1997-05-11 17:42:09 +02:00
|
|
|
SELECT '' AS ten, ABSTIME_TBL.f1 AS abstime, RELTIME_TBL.f1 AS reltime
|
1997-04-05 13:08:30 +02:00
|
|
|
WHERE (ABSTIME_TBL.f1 + RELTIME_TBL.f1)
|
2000-01-05 07:07:58 +01:00
|
|
|
< abstime 'Jan 14 14:00:00 1971'
|
1997-05-11 17:42:09 +02:00
|
|
|
ORDER BY abstime, reltime;
|
1997-04-05 13:08:30 +02:00
|
|
|
|