Back to home page

OSCL-LXR

 
 

    


0001 --
0002 -- Portions Copyright (c) 1996-2019, PostgreSQL Global Development Group
0003 --
0004 --
0005 -- TIMESTAMP
0006 -- https://github.com/postgres/postgres/blob/REL_12_BETA2/src/test/regress/sql/timestamp.sql
0007 
0008 CREATE TABLE TIMESTAMP_TBL (d1 timestamp) USING parquet;
0009 
0010 -- Test shorthand input values
0011 -- We can't just "select" the results since they aren't constants; test for
0012 -- equality instead.  We can do that by running the test inside a transaction
0013 -- block, within which the value of 'now' shouldn't change.  We also check
0014 -- that 'now' *does* change over a reasonable interval such as 100 msec.
0015 -- NOTE: it is possible for this part of the test to fail if the transaction
0016 -- block is entered exactly at local midnight; then 'now' and 'today' have
0017 -- the same values and the counts will come out different.
0018 
0019 -- PostgreSQL implicitly casts string literals to data with timestamp types, but
0020 -- Spark does not support that kind of implicit casts.
0021 INSERT INTO TIMESTAMP_TBL VALUES (timestamp('now'));
0022 -- SELECT pg_sleep(0.1);
0023 
0024 -- BEGIN;
0025 
0026 -- PostgreSQL implicitly casts string literals to data with timestamp types, but
0027 -- Spark does not support that kind of implicit casts.
0028 INSERT INTO TIMESTAMP_TBL VALUES (timestamp('now'));
0029 INSERT INTO TIMESTAMP_TBL VALUES (timestamp('today'));
0030 INSERT INTO TIMESTAMP_TBL VALUES (timestamp('yesterday'));
0031 INSERT INTO TIMESTAMP_TBL VALUES (timestamp('tomorrow'));
0032 -- time zone should be ignored by this data type
0033 INSERT INTO TIMESTAMP_TBL VALUES (timestamp('tomorrow EST'));
0034 -- [SPARK-29024] Ignore case while resolving time zones
0035 INSERT INTO TIMESTAMP_TBL VALUES (timestamp('tomorrow Zulu'));
0036 
0037 SELECT count(*) AS One FROM TIMESTAMP_TBL WHERE d1 = timestamp 'today';
0038 SELECT count(*) AS Three FROM TIMESTAMP_TBL WHERE d1 = timestamp 'tomorrow';
0039 SELECT count(*) AS One FROM TIMESTAMP_TBL WHERE d1 = timestamp 'yesterday';
0040 -- [SPARK-29025] Support seconds precision by the timestamp type
0041 -- SELECT count(*) AS One FROM TIMESTAMP_TBL WHERE d1 = timestamp(2) 'now';
0042 
0043 -- COMMIT;
0044 
0045 -- DELETE FROM TIMESTAMP_TBL;
0046 
0047 -- verify uniform transaction time within transaction block
0048 -- BEGIN;
0049 -- INSERT INTO TIMESTAMP_TBL VALUES ('now');
0050 -- SELECT pg_sleep(0.1);
0051 -- INSERT INTO TIMESTAMP_TBL VALUES ('now');
0052 -- SELECT pg_sleep(0.1);
0053 -- SELECT count(*) AS two FROM TIMESTAMP_TBL WHERE d1 = timestamp(2) 'now';
0054 -- COMMIT;
0055 
0056 TRUNCATE TABLE TIMESTAMP_TBL;
0057 
0058 -- Special values
0059 -- INSERT INTO TIMESTAMP_TBL VALUES ('-infinity');
0060 -- INSERT INTO TIMESTAMP_TBL VALUES ('infinity');
0061 -- PostgreSQL implicitly casts string literals to data with timestamp types, but
0062 -- Spark does not support that kind of implicit casts.
0063 INSERT INTO TIMESTAMP_TBL VALUES (timestamp('epoch'));
0064 -- [SPARK-27923] Spark SQL insert there obsolete special values to NULL
0065 -- Obsolete special values
0066 -- INSERT INTO TIMESTAMP_TBL VALUES ('invalid');
0067 -- INSERT INTO TIMESTAMP_TBL VALUES ('undefined');
0068 -- INSERT INTO TIMESTAMP_TBL VALUES ('current');
0069 
0070 -- [SPARK-28259] Date/Time Output Styles and Date Order Conventions
0071 -- Postgres v6.0 standard output format
0072 -- INSERT INTO TIMESTAMP_TBL VALUES ('Mon Feb 10 17:32:01 1997 PST');
0073 
0074 -- Variations on Postgres v6.1 standard output format
0075 -- INSERT INTO TIMESTAMP_TBL VALUES ('Mon Feb 10 17:32:01.000001 1997 PST');
0076 -- INSERT INTO TIMESTAMP_TBL VALUES ('Mon Feb 10 17:32:01.999999 1997 PST');
0077 -- INSERT INTO TIMESTAMP_TBL VALUES ('Mon Feb 10 17:32:01.4 1997 PST');
0078 -- INSERT INTO TIMESTAMP_TBL VALUES ('Mon Feb 10 17:32:01.5 1997 PST');
0079 -- INSERT INTO TIMESTAMP_TBL VALUES ('Mon Feb 10 17:32:01.6 1997 PST');
0080 
0081 -- ISO 8601 format
0082 -- PostgreSQL implicitly casts string literals to data with timestamp types, but
0083 -- Spark does not support that kind of implicit casts.
0084 INSERT INTO TIMESTAMP_TBL VALUES (timestamp('1997-01-02'));
0085 INSERT INTO TIMESTAMP_TBL VALUES (timestamp('1997-01-02 03:04:05'));
0086 INSERT INTO TIMESTAMP_TBL VALUES (timestamp('1997-02-10 17:32:01-08'));
0087 -- INSERT INTO TIMESTAMP_TBL VALUES ('1997-02-10 17:32:01-0800');
0088 -- INSERT INTO TIMESTAMP_TBL VALUES ('1997-02-10 17:32:01 -08:00');
0089 -- INSERT INTO TIMESTAMP_TBL VALUES ('19970210 173201 -0800');
0090 -- INSERT INTO TIMESTAMP_TBL VALUES ('1997-06-10 17:32:01 -07:00');
0091 INSERT INTO TIMESTAMP_TBL VALUES (timestamp('2001-09-22T18:19:20'));
0092 
0093 -- POSIX format (note that the timezone abbrev is just decoration here)
0094 -- INSERT INTO TIMESTAMP_TBL VALUES ('2000-03-15 08:14:01 GMT+8');
0095 -- INSERT INTO TIMESTAMP_TBL VALUES ('2000-03-15 13:14:02 GMT-1');
0096 -- INSERT INTO TIMESTAMP_TBL VALUES ('2000-03-15 12:14:03 GMT-2');
0097 -- INSERT INTO TIMESTAMP_TBL VALUES ('2000-03-15 03:14:04 PST+8');
0098 -- INSERT INTO TIMESTAMP_TBL VALUES ('2000-03-15 02:14:05 MST+7:00');
0099 
0100 -- Variations for acceptable input formats
0101 -- INSERT INTO TIMESTAMP_TBL VALUES ('Feb 10 17:32:01 1997 -0800');
0102 -- INSERT INTO TIMESTAMP_TBL VALUES ('Feb 10 17:32:01 1997');
0103 -- INSERT INTO TIMESTAMP_TBL VALUES ('Feb 10 5:32PM 1997');
0104 -- INSERT INTO TIMESTAMP_TBL VALUES ('1997/02/10 17:32:01-0800');
0105 -- INSERT INTO TIMESTAMP_TBL VALUES ('1997-02-10 17:32:01 PST');
0106 -- INSERT INTO TIMESTAMP_TBL VALUES ('Feb-10-1997 17:32:01 PST');
0107 -- INSERT INTO TIMESTAMP_TBL VALUES ('02-10-1997 17:32:01 PST');
0108 -- INSERT INTO TIMESTAMP_TBL VALUES ('19970210 173201 PST');
0109 -- set datestyle to ymd;
0110 -- INSERT INTO TIMESTAMP_TBL VALUES ('97FEB10 5:32:01PM UTC');
0111 -- INSERT INTO TIMESTAMP_TBL VALUES ('97/02/10 17:32:01 UTC');
0112 -- reset datestyle;
0113 -- INSERT INTO TIMESTAMP_TBL VALUES ('1997.041 17:32:01 UTC');
0114 -- INSERT INTO TIMESTAMP_TBL VALUES ('19970210 173201 America/New_York');
0115 -- this fails (even though TZ is a no-op, we still look it up)
0116 -- INSERT INTO TIMESTAMP_TBL VALUES ('19970710 173201 America/Does_not_exist');
0117 
0118 -- Check date conversion and date arithmetic
0119 -- INSERT INTO TIMESTAMP_TBL VALUES ('1997-06-10 18:32:01 PDT');
0120 
0121 -- INSERT INTO TIMESTAMP_TBL VALUES ('Feb 10 17:32:01 1997');
0122 -- INSERT INTO TIMESTAMP_TBL VALUES ('Feb 11 17:32:01 1997');
0123 -- INSERT INTO TIMESTAMP_TBL VALUES ('Feb 12 17:32:01 1997');
0124 -- INSERT INTO TIMESTAMP_TBL VALUES ('Feb 13 17:32:01 1997');
0125 -- INSERT INTO TIMESTAMP_TBL VALUES ('Feb 14 17:32:01 1997');
0126 -- INSERT INTO TIMESTAMP_TBL VALUES ('Feb 15 17:32:01 1997');
0127 -- INSERT INTO TIMESTAMP_TBL VALUES ('Feb 16 17:32:01 1997');
0128 
0129 -- INSERT INTO TIMESTAMP_TBL VALUES ('Feb 16 17:32:01 0097 BC');
0130 -- INSERT INTO TIMESTAMP_TBL VALUES ('Feb 16 17:32:01 0097');
0131 -- INSERT INTO TIMESTAMP_TBL VALUES ('Feb 16 17:32:01 0597');
0132 -- INSERT INTO TIMESTAMP_TBL VALUES ('Feb 16 17:32:01 1097');
0133 -- INSERT INTO TIMESTAMP_TBL VALUES ('Feb 16 17:32:01 1697');
0134 -- INSERT INTO TIMESTAMP_TBL VALUES ('Feb 16 17:32:01 1797');
0135 -- INSERT INTO TIMESTAMP_TBL VALUES ('Feb 16 17:32:01 1897');
0136 -- INSERT INTO TIMESTAMP_TBL VALUES ('Feb 16 17:32:01 1997');
0137 -- INSERT INTO TIMESTAMP_TBL VALUES ('Feb 16 17:32:01 2097');
0138 
0139 -- INSERT INTO TIMESTAMP_TBL VALUES ('Feb 28 17:32:01 1996');
0140 -- INSERT INTO TIMESTAMP_TBL VALUES ('Feb 29 17:32:01 1996');
0141 -- INSERT INTO TIMESTAMP_TBL VALUES ('Mar 01 17:32:01 1996');
0142 -- INSERT INTO TIMESTAMP_TBL VALUES ('Dec 30 17:32:01 1996');
0143 -- INSERT INTO TIMESTAMP_TBL VALUES ('Dec 31 17:32:01 1996');
0144 -- INSERT INTO TIMESTAMP_TBL VALUES ('Jan 01 17:32:01 1997');
0145 -- INSERT INTO TIMESTAMP_TBL VALUES ('Feb 28 17:32:01 1997');
0146 -- INSERT INTO TIMESTAMP_TBL VALUES ('Feb 29 17:32:01 1997');
0147 -- INSERT INTO TIMESTAMP_TBL VALUES ('Mar 01 17:32:01 1997');
0148 -- INSERT INTO TIMESTAMP_TBL VALUES ('Dec 30 17:32:01 1997');
0149 -- INSERT INTO TIMESTAMP_TBL VALUES ('Dec 31 17:32:01 1997');
0150 -- INSERT INTO TIMESTAMP_TBL VALUES ('Dec 31 17:32:01 1999');
0151 -- INSERT INTO TIMESTAMP_TBL VALUES ('Jan 01 17:32:01 2000');
0152 -- INSERT INTO TIMESTAMP_TBL VALUES ('Dec 31 17:32:01 2000');
0153 -- INSERT INTO TIMESTAMP_TBL VALUES ('Jan 01 17:32:01 2001');
0154 
0155 -- Currently unsupported syntax and ranges
0156 -- INSERT INTO TIMESTAMP_TBL VALUES ('Feb 16 17:32:01 -0097');
0157 -- INSERT INTO TIMESTAMP_TBL VALUES ('Feb 16 17:32:01 5097 BC');
0158 
0159 SELECT '' AS `64`, d1 FROM TIMESTAMP_TBL;
0160 
0161 -- [SPARK-28253] Date/Timestamp type have different low value and high value with Spark
0162 -- Check behavior at the lower boundary of the timestamp range
0163 -- SELECT '4714-11-24 00:00:00 BC'::timestamp;
0164 -- SELECT '4714-11-23 23:59:59 BC'::timestamp;  -- out of range
0165 -- The upper boundary differs between integer and float timestamps, so no check
0166 
0167 -- Demonstrate functions and operators
0168 SELECT '' AS `48`, d1 FROM TIMESTAMP_TBL
0169    WHERE d1 > timestamp '1997-01-02';
0170 
0171 SELECT '' AS `15`, d1 FROM TIMESTAMP_TBL
0172    WHERE d1 < timestamp '1997-01-02';
0173 
0174 SELECT '' AS one, d1 FROM TIMESTAMP_TBL
0175    WHERE d1 = timestamp '1997-01-02';
0176 
0177 SELECT '' AS `63`, d1 FROM TIMESTAMP_TBL
0178    WHERE d1 != timestamp '1997-01-02';
0179 
0180 SELECT '' AS `16`, d1 FROM TIMESTAMP_TBL
0181    WHERE d1 <= timestamp '1997-01-02';
0182 
0183 SELECT '' AS `49`, d1 FROM TIMESTAMP_TBL
0184    WHERE d1 >= timestamp '1997-01-02';
0185 
0186 SELECT '' AS `54`, d1 - timestamp '1997-01-02' AS diff
0187    FROM TIMESTAMP_TBL WHERE d1 BETWEEN '1902-01-01' AND '2038-01-01';
0188 
0189 SELECT '' AS date_trunc_week, date_trunc( 'week', timestamp '2004-02-29 15:44:17.71393' ) AS week_trunc;
0190 
0191 -- Test casting within a BETWEEN qualifier
0192 SELECT '' AS `54`, d1 - timestamp '1997-01-02' AS diff
0193   FROM TIMESTAMP_TBL
0194   WHERE d1 BETWEEN timestamp '1902-01-01'
0195    AND timestamp '2038-01-01';
0196 
0197 SELECT '' AS `54`, d1 as `timestamp`,
0198     date_part( 'year', d1) AS `year`, date_part( 'month', d1) AS `month`,
0199     date_part( 'day', d1) AS `day`, date_part( 'hour', d1) AS `hour`,
0200     date_part( 'minute', d1) AS `minute`, date_part( 'second', d1) AS `second`
0201     FROM TIMESTAMP_TBL WHERE d1 BETWEEN '1902-01-01' AND '2038-01-01';
0202 
0203 -- SELECT '' AS `54`, d1 as `timestamp`,
0204 --     date_part( 'quarter', d1) AS quarter, date_part( 'msec', d1) AS msec,
0205 --     date_part( 'usec', d1) AS usec
0206 --     FROM TIMESTAMP_TBL WHERE d1 BETWEEN '1902-01-01' AND '2038-01-01';
0207 
0208 -- SELECT '' AS `54`, d1 as `timestamp`,
0209 --     date_part( 'isoyear', d1) AS isoyear, date_part( 'week', d1) AS week,
0210 --     date_part( 'dow', d1) AS dow
0211 --     FROM TIMESTAMP_TBL WHERE d1 BETWEEN '1902-01-01' AND '2038-01-01';
0212 
0213 -- [SPARK-28137] Data Type Formatting Functions
0214 -- TO_CHAR()
0215 -- SELECT '' AS to_char_1, to_char(d1, 'DAY Day day DY Dy dy MONTH Month month RM MON Mon mon')
0216 --    FROM TIMESTAMP_TBL;
0217 
0218 -- SELECT '' AS to_char_2, to_char(d1, 'FMDAY FMDay FMday FMMONTH FMMonth FMmonth FMRM')
0219 --    FROM TIMESTAMP_TBL;
0220 
0221 -- SELECT '' AS to_char_3, to_char(d1, 'Y,YYY YYYY YYY YY Y CC Q MM WW DDD DD D J')
0222 --    FROM TIMESTAMP_TBL;
0223 
0224 -- SELECT '' AS to_char_4, to_char(d1, 'FMY,YYY FMYYYY FMYYY FMYY FMY FMCC FMQ FMMM FMWW FMDDD FMDD FMD FMJ')
0225 --    FROM TIMESTAMP_TBL;
0226 
0227 -- SELECT '' AS to_char_5, to_char(d1, 'HH HH12 HH24 MI SS SSSS')
0228 --    FROM TIMESTAMP_TBL;
0229 
0230 -- SELECT '' AS to_char_6, to_char(d1, E'"HH:MI:SS is" HH:MI:SS "\\"text between quote marks\\""')
0231 --    FROM TIMESTAMP_TBL;
0232 
0233 -- SELECT '' AS to_char_7, to_char(d1, 'HH24--text--MI--text--SS')
0234 --    FROM TIMESTAMP_TBL;
0235 
0236 -- SELECT '' AS to_char_8, to_char(d1, 'YYYYTH YYYYth Jth')
0237 --    FROM TIMESTAMP_TBL;
0238 
0239 -- SELECT '' AS to_char_9, to_char(d1, 'YYYY A.D. YYYY a.d. YYYY bc HH:MI:SS P.M. HH:MI:SS p.m. HH:MI:SS pm')
0240 --    FROM TIMESTAMP_TBL;
0241 
0242 -- SELECT '' AS to_char_10, to_char(d1, 'IYYY IYY IY I IW IDDD ID')
0243 --    FROM TIMESTAMP_TBL;
0244 
0245 -- SELECT '' AS to_char_11, to_char(d1, 'FMIYYY FMIYY FMIY FMI FMIW FMIDDD FMID')
0246 --    FROM TIMESTAMP_TBL;
0247 
0248 
0249 -- timestamp numeric fields constructor
0250 SELECT make_timestamp(2014,12,28,6,30,45.887);
0251 
0252 DROP TABLE TIMESTAMP_TBL;