abstime.sql
上传用户:blenddy
上传日期:2007-01-07
资源大小:6495k
文件大小:3k
源码类别:

数据库系统

开发平台:

Unix_Linux

  1. -- **** testing built-in time types: abstime, reltime, and tinterval ****
  2. --
  3. -- timezones may vary based not only on location but the operating
  4. -- system.  the main correctness issue is that the OS may not get 
  5. -- daylight savings time right for times prior to Unix epoch (jan 1 1970).
  6. --
  7. CREATE TABLE ABSTIME_TBL (f1 abstime);
  8. INSERT INTO ABSTIME_TBL (f1) VALUES ('Jan 14, 1973 03:14:21');
  9. -- was INSERT INTO ABSTIME_TBL (f1) VALUES ('now'::abstime):
  10. INSERT INTO ABSTIME_TBL (f1) VALUES ('Mon May  1 00:30:30 1995'::abstime);
  11. INSERT INTO ABSTIME_TBL (f1) VALUES ('epoch'::abstime);
  12. INSERT INTO ABSTIME_TBL (f1) VALUES ('current'::abstime);
  13. INSERT INTO ABSTIME_TBL (f1) VALUES ('infinity'::abstime);
  14. INSERT INTO ABSTIME_TBL (f1) VALUES ('-infinity'::abstime);
  15. INSERT INTO ABSTIME_TBL (f1) VALUES ('May 10, 1947 23:59:12');
  16. -- what happens if we specify slightly misformatted abstime? 
  17. INSERT INTO ABSTIME_TBL (f1) VALUES ('Feb 35, 1946 10:00:00');
  18. INSERT INTO ABSTIME_TBL (f1) VALUES ('Feb 28, 1984 25:08:10');
  19. -- badly formatted abstimes:  these should result in invalid abstimes 
  20. INSERT INTO ABSTIME_TBL (f1) VALUES ('bad date format');
  21. INSERT INTO ABSTIME_TBL (f1) VALUES ('Jun 10, 1843');
  22. -- test abstime operators
  23. SELECT '' AS eight, ABSTIME_TBL.*;
  24. SELECT '' AS six, ABSTIME_TBL.*
  25.    WHERE ABSTIME_TBL.f1 < 'Jun 30, 2001'::abstime;
  26. SELECT '' AS six, ABSTIME_TBL.*
  27.    WHERE ABSTIME_TBL.f1 > '-infinity'::abstime;
  28. SELECT '' AS six, ABSTIME_TBL.*
  29.    WHERE 'May 10, 1947 23:59:12'::abstime <> ABSTIME_TBL.f1;
  30. SELECT '' AS one, ABSTIME_TBL.*
  31.    WHERE 'current'::abstime = ABSTIME_TBL.f1;
  32. SELECT '' AS three, ABSTIME_TBL.*
  33.    WHERE 'epoch'::abstime >= ABSTIME_TBL.f1;
  34. SELECT '' AS four, ABSTIME_TBL.*
  35.    WHERE ABSTIME_TBL.f1 <= 'Jan 14, 1973 03:14:21'::abstime;
  36. SELECT '' AS four, ABSTIME_TBL.*
  37.   WHERE ABSTIME_TBL.f1 <?>
  38. '["Apr 1 1950 00:00:00" "Dec 30 1999 23:00:00"]'::tinterval;
  39. -- these four queries should return the same answer
  40. -- the "infinity" and "-infinity" tuples in ABSTIME_TBL cannot be added and
  41. -- therefore, should not show up in the results.
  42. SELECT '' AS three, ABSTIME_TBL.*
  43.   WHERE  (ABSTIME_TBL.f1 + '@ 3 year'::reltime) -- +3 years
  44. < 'Jan 14 14:00:00 1977'::abstime;
  45. SELECT '' AS three, ABSTIME_TBL.*
  46.    WHERE  (ABSTIME_TBL.f1 + '@ 3 year ago'::reltime) -- -3 years
  47. < 'Jan 14 14:00:00 1971'::abstime;
  48. SELECT '' AS three, ABSTIME_TBL.*
  49.    WHERE  (ABSTIME_TBL.f1 - '@ 3 year'::reltime)        -- -(+3) years
  50. < 'Jan 14 14:00:00 1971'::abstime;
  51. SELECT '' AS three, ABSTIME_TBL.*
  52.    WHERE  (ABSTIME_TBL.f1 - '@ 3 year ago'::reltime)    -- -(-3) years
  53.         < 'Jan 14 14:00:00 1977'::abstime;
  54. SELECT '' AS ten, ABSTIME_TBL.f1 AS abstime, RELTIME_TBL.f1 AS reltime
  55.    WHERE (ABSTIME_TBL.f1 + RELTIME_TBL.f1)
  56. < 'Jan 14 14:00:00 1971'::abstime
  57.    ORDER BY abstime, reltime;