本文為您介紹MaxCompute支援的日期函數,包括日期函數的命令格式、參數說明和使用樣本。您可以根據實際需要選擇合適的日期函數,以完成日期計算或轉換。
函數 | 功能 |
計算日期值增加指定月數後的日期。 | |
返回當前TIMESTAMP類型的時間戳記。 | |
返回當前系統的時區值。 | |
按照指定的幅度增減天數(僅支援以日為單位增減),與 | |
按照指定的單位(支援以年、月、日、時、分或秒為單位)和幅度修改日期值。 | |
將日期值轉換為指定格式的字串。 | |
按照指定的幅度增減天數,與 | |
計算兩個日期的差值並按照指定的單位表示。 | |
提取日期中符合指定時間單位的欄位值。 | |
提取日期按照指定時間單位截取後的值。 | |
返回日期值的天。 | |
返回日部分的值。 | |
返回日期的星期值。 | |
返回日期是當年中第幾天。 | |
擷取日期TIMESTAMP中指定單位的部分。 | |
將數字型的UNIX值轉換為日期值。 | |
將一個UTC時區的時間戳記轉換為一個指定時區的時間戳記。 | |
擷取當前系統時間。 | |
返回日期小時部分的值。 | |
判斷一個日期文字能否根據指定的格式串轉換為一個日期值。 | |
返回日期值所在月份的最後一天日期。 | |
擷取日期所在月的最後一天。 | |
返回日期分鐘部分的值。 | |
返回日期值所屬月份。 | |
返回指定日期值間的月數。 | |
返回大於日期值且與指定周相匹配的第一個日期。 | |
返回當前系統日期與時間。 | |
返回日期值所屬季度。 | |
返回日期秒數部分的值。 | |
將日期按照指定格式轉換為字串。 | |
將指定格式的字串轉換為日期值。 | |
將指定日期轉換為以毫秒為單位的UNIX時間戳記。 | |
將日期轉換為整型的UNIX格式的日期值。 | |
返回日期值是當前周的第幾天。 | |
返回日期值位於當年的第幾周。 | |
返回日期值的年。 |
注意事項
升級到MaxCompute 2.0後,產品擴充了部分函數。如果您用到的函數涉及新資料類型(TINYINT、SMALLINT、INT、FLOAT、VARCHAR、TIMESTAMP或BINARY),在使用擴充函數時,需要執行如下語句開啟新資料類型開關:
樣本資料
為便於理解各函數的使用方法,本文為您提供來源資料,基於來源資料提供函數相關樣本。建立表mf_date_fun_t,並添加資料,命令樣本如下。
create table if not exists mf_date_fun_t(
id int,
date1 date,
datetime1 datetime,
timestamp1 timestamp,
date2 date,
datetime2 datetime,
timestamp2 timestamp,
date3 string,
date4 bigint);
insert into mf_date_fun_t values
(1,DATE'2021-11-29',DATETIME'2021-11-29 00:01:00',TIMESTAMP'2021-01-11 00:00:00.123456789',DATE'2021-10-29',DATETIME'2021-10-29 00:00:00',TIMESTAMP'2021-10-11 00:00:00.123456789','2021-11-20',123456780),
(2,DATE'2021-11-28',DATETIME'2021-11-28 00:02:00',TIMESTAMP'2021-02-11 00:00:00.123456789',DATE'2021-10-29',DATETIME'2021-10-29 00:00:00',TIMESTAMP'2021-10-11 00:00:00.123456789','2021-11-21',123456781),
(3,DATE'2021-11-27',DATETIME'2021-11-27 00:03:00',TIMESTAMP'2021-03-11 00:00:00.123456789',DATE'2021-10-29',DATETIME'2021-10-29 00:00:00',TIMESTAMP'2021-10-11 00:00:00.123456789','2021-11-22',123456782),
(4,DATE'2021-11-26',DATETIME'2021-11-26 00:04:00',TIMESTAMP'2021-04-11 00:00:00.123456789',DATE'2021-10-29',DATETIME'2021-10-29 00:00:00',TIMESTAMP'2021-10-11 00:00:00.123456789','2021-11-23',123456783),
(5,DATE'2021-11-25',DATETIME'2021-11-25 00:05:00',TIMESTAMP'2021-05-11 00:00:00.123456789',DATE'2021-10-29',DATETIME'2021-10-29 00:00:00',TIMESTAMP'2021-10-11 00:00:00.123456789','2021-11-24',123456784),
(6,DATE'2021-11-24',DATETIME'2021-11-24 00:06:00',TIMESTAMP'2021-06-11 00:00:00.123456789',DATE'2021-10-29',DATETIME'2021-10-29 00:00:00',TIMESTAMP'2021-10-11 00:00:00.123456789','2021-11-25',123456785),
(7,DATE'2021-11-23',DATETIME'2021-11-23 00:07:00',TIMESTAMP'2021-07-11 00:00:00.123456789',DATE'2021-10-29',DATETIME'2021-10-29 00:00:00',TIMESTAMP'2021-10-11 00:00:00.123456789','2021-11-26',123456786),
(8,DATE'2021-11-22',DATETIME'2021-11-22 00:08:00',TIMESTAMP'2021-08-11 00:00:00.123456789',DATE'2021-10-29',DATETIME'2021-10-29 00:00:00',TIMESTAMP'2021-10-11 00:00:00.123456789','2021-11-27',123456787),
(9,DATE'2021-11-21',DATETIME'2021-11-21 00:09:00',TIMESTAMP'2021-09-11 00:00:00.123456789',DATE'2021-10-29',DATETIME'2021-10-29 00:00:00',TIMESTAMP'2021-10-11 00:00:00.123456789','2021-11-28',123456788),
(10,DATE'2021-11-20',DATETIME'2021-11-20 00:10:00',TIMESTAMP'2021-10-11 00:00:00.123456789',DATE'2021-10-29',DATETIME'2021-10-29 00:00:00',TIMESTAMP'2021-10-11 00:00:00.123456789','2021-11-29',123456789);
查詢表mf_date_fun_t中的資料,命令樣本如下:
SELECT * FROM mf_date_fun_t;
返回結果如下。
+------------+------------+---------------------+-------------------------+------------+---------------------+-------------------------+------------+------------+
| id | date1 | datetime1 | timestamp1 | date2 | datetime2 | timestamp2 | date3 | date4 |
+------------+------------+---------------------+-------------------------+------------+---------------------+-------------------------+------------+------------+
| 1 | 2021-11-29 | 2021-11-29 00:01:00 | 2021-01-11 00:00:00.123 | 2021-10-29 | 2021-10-29 00:00:00 | 2021-10-11 00:00:00.123 | 2021-11-20 | 123456780 |
| 2 | 2021-11-28 | 2021-11-28 00:02:00 | 2021-02-11 00:00:00.123 | 2021-10-29 | 2021-10-29 00:00:00 | 2021-10-11 00:00:00.123 | 2021-11-21 | 123456781 |
| 3 | 2021-11-27 | 2021-11-27 00:03:00 | 2021-03-11 00:00:00.123 | 2021-10-29 | 2021-10-29 00:00:00 | 2021-10-11 00:00:00.123 | 2021-11-22 | 123456782 |
| 4 | 2021-11-26 | 2021-11-26 00:04:00 | 2021-04-11 00:00:00.123 | 2021-10-29 | 2021-10-29 00:00:00 | 2021-10-11 00:00:00.123 | 2021-11-23 | 123456783 |
| 5 | 2021-11-25 | 2021-11-25 00:05:00 | 2021-05-11 00:00:00.123 | 2021-10-29 | 2021-10-29 00:00:00 | 2021-10-11 00:00:00.123 | 2021-11-24 | 123456784 |
| 6 | 2021-11-24 | 2021-11-24 00:06:00 | 2021-06-11 00:00:00.123 | 2021-10-29 | 2021-10-29 00:00:00 | 2021-10-11 00:00:00.123 | 2021-11-25 | 123456785 |
| 7 | 2021-11-23 | 2021-11-23 00:07:00 | 2021-07-11 00:00:00.123 | 2021-10-29 | 2021-10-29 00:00:00 | 2021-10-11 00:00:00.123 | 2021-11-26 | 123456786 |
| 8 | 2021-11-22 | 2021-11-22 00:08:00 | 2021-08-11 00:00:00.123 | 2021-10-29 | 2021-10-29 00:00:00 | 2021-10-11 00:00:00.123 | 2021-11-27 | 123456787 |
| 9 | 2021-11-21 | 2021-11-21 00:09:00 | 2021-09-11 00:00:00.123 | 2021-10-29 | 2021-10-29 00:00:00 | 2021-10-11 00:00:00.123 | 2021-11-28 | 123456788 |
| 10 | 2021-11-20 | 2021-11-20 00:10:00 | 2021-10-11 00:00:00.123 | 2021-10-29 | 2021-10-29 00:00:00 | 2021-10-11 00:00:00.123 | 2021-11-29 | 123456789 |
+------------+------------+---------------------+-------------------------+------------+---------------------+-------------------------+------------+------------+
ADD_MONTHS
命令格式
string add_months(date|datetime|timestamp|string <startdate>, int <num_months>)
命令說明
返回開始日期startdate增加num_months個月後的日期。此函數為MaxCompute 2.0擴充函數。
參數說明
startdate:必填。DATE、DATETIME、TIMESTAMP或STRING類型,格式為
yyyy-mm-dd
、yyyy-mm-dd hh:mi:ss
或yyyy-mm-dd hh:mi:ss.ff3
。取值為STRING類型格式時,至少要包含yyyy-mm-dd
且不含多餘的字串。num_months:必填。INT型數值。
傳回值說明
返回STRING類型的日期值,格式為
yyyy-mm-dd
。返回規則如下:startdate非DATE、DATETIME、TIMESTAMP或STRING類型,或格式不符合要求時,返回NULL。
startdate值為NULL時,返回報錯。
num_months值為NULL時,返回NULL。
樣本
待用資料樣本
--返回2017-05-14。 select add_months('2017-02-14',3); --返回0017-05-14。 select add_months('17-2-14',3); --返回2017-05-14。 select add_months('2017-02-14 21:30:00',3); --返回NULL。 select add_months('20170214',3); --返回NULL。 select add_months('2017-02-14 21:30:00',null);
表資料樣本
基於樣本資料,將date1、datetime1、timestamp1和date3列日期轉換為整型的UNIX格式的日期值,命令樣本如下。
--開啟2.0新類型。此命令需要與SQL語句一起提交。 set odps.sql.type.system.odps2=true; select date1, add_months(date1,1) as date1_add_months, datetime1, add_months(datetime1, 2) as datetime1_add_months, timestamp1, add_months(timestamp1,3) as timestamp1_add_months, date3, add_months(date3,4) as date3_add_months from mf_date_fun_t;
返回結果如下。
+------------+------------------+---------------------+----------------------+-------------------------------+-----------------------+------------+------------------+ | date1 | date1_add_months | datetime1 | datetime1_add_months | timestamp1 | timestamp1_add_months | date3 | date3_add_months | +------------+------------------+---------------------+----------------------+-------------------------------+-----------------------+------------+------------------+ | 2021-11-29 | 2021-12-29 | 2021-11-29 00:01:00 | 2022-01-29 | 2021-01-11 00:00:00.123456789 | 2021-04-11 | 2021-11-20 | 2022-03-20 | | 2021-11-28 | 2021-12-28 | 2021-11-28 00:02:00 | 2022-01-28 | 2021-02-11 00:00:00.123456789 | 2021-05-11 | 2021-11-21 | 2022-03-21 | | 2021-11-27 | 2021-12-27 | 2021-11-27 00:03:00 | 2022-01-27 | 2021-03-11 00:00:00.123456789 | 2021-06-11 | 2021-11-22 | 2022-03-22 | | 2021-11-26 | 2021-12-26 | 2021-11-26 00:04:00 | 2022-01-26 | 2021-04-11 00:00:00.123456789 | 2021-07-11 | 2021-11-23 | 2022-03-23 | | 2021-11-25 | 2021-12-25 | 2021-11-25 00:05:00 | 2022-01-25 | 2021-05-11 00:00:00.123456789 | 2021-08-11 | 2021-11-24 | 2022-03-24 | | 2021-11-24 | 2021-12-24 | 2021-11-24 00:06:00 | 2022-01-24 | 2021-06-11 00:00:00.123456789 | 2021-09-11 | 2021-11-25 | 2022-03-25 | | 2021-11-23 | 2021-12-23 | 2021-11-23 00:07:00 | 2022-01-23 | 2021-07-11 00:00:00.123456789 | 2021-10-11 | 2021-11-26 | 2022-03-26 | | 2021-11-22 | 2021-12-22 | 2021-11-22 00:08:00 | 2022-01-22 | 2021-08-11 00:00:00.123456789 | 2021-11-11 | 2021-11-27 | 2022-03-27 | | 2021-11-21 | 2021-12-21 | 2021-11-21 00:09:00 | 2022-01-21 | 2021-09-11 00:00:00.123456789 | 2021-12-11 | 2021-11-28 | 2022-03-28 | | 2021-11-20 | 2021-12-20 | 2021-11-20 00:10:00 | 2022-01-20 | 2021-10-11 00:00:00.123456789 | 2022-01-11 | 2021-11-29 | 2022-03-29 | +------------+------------------+---------------------+----------------------+-------------------------------+-----------------------+------------+------------------+
CURRENT_TIMESTAMP
命令格式
timestamp current_timestamp()
命令說明
返回當前TIMESTAMP類型的時間戳記,值不固定。此函數為MaxCompute 2.0擴充函數。
傳回值說明
返回TIMESTAMP類型。
樣本
--返回'2017-08-03 11:50:30.661'。 set odps.sql.type.system.odps2=true; select current_timestamp();
CURRENT_TIMEZONE
命令格式
string current_timezone()
命令說明
返回當前系統的時區資訊。
傳回值說明
返回STRING類型。
樣本
--返回Asia/Shanghai。 select current_timezone();
DATE_ADD
命令格式
date date_add(date|timestamp|string <startdate>, bigint <delta>)
命令說明
按照delta幅度增減startdate日期的天數。如果您需要擷取在目前時間基礎上指定變動幅度的日期,請結合GETDATE函數使用。
本命令與DATE_SUB的增減邏輯相反。
參數說明
startdate:必填。起始日期值。支援DATE、DATETIME或STRING類型。
如果參數為STRING類型,且MaxCompute專案的資料類型版本是1.0,則會隱式轉換為DATE類型後參與運算,且STRING參數格式至少要包含
'yyyy-mm-dd'
。例如'2019-12-27'
。delta:必填。修改幅度。BIGINT類型。如果delta大於0,則增;delta小於0,則減;delta等於0,不增不減。
傳回值說明
返回DATE類型,格式為
yyyy-mm-dd
。返回規則如下:startdate非DATE、DATETIME或STRING類型時,返回報錯。
startdate值為NULL時,返回報錯。
delta值為NULL時,返回NULL。
樣本
待用資料樣本
--返回2005-03-01。加1天,結果超出當年2月份的最後1天,實際值為下個月的第1天。 select date_add(datetime '2005-02-28 00:00:00', 1); --返回2005-02-27。減1天。 select date_add(date '2005-02-28', -1); --返回2005-03-20。 set odps.sql.type.system.odps2=false; select date_add('2005-02-28 00:00:00', 20); --假設目前時間為2020-11-17 16:31:44,返回2020-11-16。 select date_add(getdate(),-1); --返回NULL。 select date_add('2005-02-28 00:00:00', null);
表資料樣本
基於樣本資料,對date1、datetime1和timestamp1列按照幅度變化天數,命令樣本如下。
--開啟2.0新類型。此命令需要與SQL語句一起提交。 set odps.sql.type.system.odps2=true; select date1, date_add(date1,1) as date1_date_add, datetime1, date_add(datetime1,-1) as datetime1_date_add, timestamp1, date_add(timestamp1,0) as timestamp1_date_add from mf_date_fun_t;
返回結果如下。
+------------+----------------+---------------------+-------------------+-------------------------------+--------------------+ | date1 | date1_date_add | datetime1 | datetime1_date_add| timestamp1 | timestamp1_date_add| +------------+----------------+---------------------+-------------------+-------------------------------+--------------------+ | 2021-11-29 | 2021-11-30 | 2021-11-29 00:01:00 | 2021-11-28 | 2021-01-11 00:00:00.123456789 | 2021-01-11 | | 2021-11-28 | 2021-11-29 | 2021-11-28 00:02:00 | 2021-11-27 | 2021-02-11 00:00:00.123456789 | 2021-02-11 | | 2021-11-27 | 2021-11-28 | 2021-11-27 00:03:00 | 2021-11-26 | 2021-03-11 00:00:00.123456789 | 2021-03-11 | | 2021-11-26 | 2021-11-27 | 2021-11-26 00:04:00 | 2021-11-25 | 2021-04-11 00:00:00.123456789 | 2021-04-11 | | 2021-11-25 | 2021-11-26 | 2021-11-25 00:05:00 | 2021-11-24 | 2021-05-11 00:00:00.123456789 | 2021-05-11 | | 2021-11-24 | 2021-11-25 | 2021-11-24 00:06:00 | 2021-11-23 | 2021-06-11 00:00:00.123456789 | 2021-06-11 | | 2021-11-23 | 2021-11-24 | 2021-11-23 00:07:00 | 2021-11-22 | 2021-07-11 00:00:00.123456789 | 2021-07-11 | | 2021-11-22 | 2021-11-23 | 2021-11-22 00:08:00 | 2021-11-21 | 2021-08-11 00:00:00.123456789 | 2021-08-11 | | 2021-11-21 | 2021-11-22 | 2021-11-21 00:09:00 | 2021-11-20 | 2021-09-11 00:00:00.123456789 | 2021-09-11 | | 2021-11-20 | 2021-11-21 | 2021-11-20 00:10:00 | 2021-11-19 | 2021-10-11 00:00:00.123456789 | 2021-10-11 | +------------+----------------+---------------------+-------------------+-------------------------------+--------------------+
DATEADD
命令格式
date|datetime dateadd(date|datetime|timestamp <date>, bigint <delta>, string <datepart>)
命令說明
按照指定的單位datepart和幅度delta修改date的值。如果您需要擷取在目前時間基礎上指定變動幅度的日期,請結合GETDATE函數使用。
參數說明
date:必填。日期值,DATE、DATETIME或TIMESTAMP類型。
如果參數為STRING類型,格式符合DATETIME類型的格式,即
yyyy-mm-dd hh:mi:ss
,例如2021-08-28 00:00:00
,且MaxCompute專案的資料類型版本是1.0,則會隱式轉換為DATETIME類型後參與運算。delta:必填。修改幅度,BIGINT類型。如果delta大於0,則增,否則減。
如果參數為STRING或DOUBLE類型,則會隱式轉換為BIGINT類型後參與運算。
說明按照指定的單位增減delta時,會導致更高單位的進位或退位。年、月、時、分、秒分別按照10進位、12進位、24進位、60進位進行計算。
當delta的單位是月時,如果delta的月部分在增加delta值之後不造成Day溢出,則保持Day值不變,否則將Day值設定為結果月份的最後1天。
datepart:必填。指定修改的單位,STRING類型常量。非常量、不支援的格式或其他類型會返回報錯。
此欄位的取值遵循STRING與DATETIME類型轉換的約定,即
yyyy
表示年,mm
表示月,dd
表示天。關於類型轉換的規則,詳情請參見資料類型轉換。該欄位也支援擴充的日期格式:年-year
、月-month
或-mon
、日-day
和小時-hour
。
傳回值說明
返回DATE或DATETIME類型,格式為
yyyy-mm-dd
或yyyy-mm-dd hh:mi:ss
。返回規則如下:date非DATE、DATETIME或TIMESTAMP類型時,返回報錯。
date值為NULL時,返回報錯。
delta或datepart值為NULL時,返回NULL。
樣本
待用資料樣本
樣本1:常見用法。
--返回2005-03-01 00:00:00。加1天,結果超出當年2月份的最後一天,實際值為下個月的第1天。 select dateadd(datetime '2005-02-28 00:00:00', 1, 'dd'); --返回2005-02-27 00:00:00。減1天。 select dateadd(datetime '2005-02-28 00:00:00', -1, 'dd'); --返回2006-10-28 00:00:00。加20個月,月份溢出,年份加1。 select dateadd(datetime '2005-02-28 00:00:00', 20, 'mm'); --返回2005-03-28 00:00:00。 select dateadd(datetime '2005-02-28 00:00:00', 1, 'mm'); --返回2005-02-28 00:00:00。2005年2月沒有29日,日期截取至當月最後1天。 select dateadd(datetime '2005-01-29 00:00:00', 1, 'mm'); --返回2005-02-28 00:00:00。 select dateadd(datetime '2005-03-30 00:00:00', -1, 'mm'); --返回2005-03-18。 select dateadd(date '2005-02-18', 1, 'mm'); --開啟2.0新類型。此命令需要與SQL語句一起提交。返回2005-03-18 00:00:00.0。 set odps.sql.type.system.odps2=true; select dateadd(timestamp '2005-02-18 00:00:00', 1, 'mm'); --假設目前時間為2020-11-17 16:31:44,返回2020-11-16 16:31:44。 select dateadd(getdate(),-1,'dd'); --返回NULL。 select dateadd(date '2005-02-18', 1, null);
樣本2:用常量表示。
在MaxCompute SQL中,DATETIME類型沒有直接的常量表示方式,錯誤命令樣本如下:
select dateadd(2005-03-30 00:00:00, -1, 'mm');
如果需要描述DATETIME類型的常量,正確命令樣本如下:
--將STRING類型常量顯式轉換為DATETIME類型,返回2005-02-28 00:00:00。 select dateadd(cast("2005-03-30 00:00:00" as datetime), -1, 'mm');
樣本3:輸入參數為STRING類型。
--如下輸入參數為STRING類型,但不符合DATETIME類型格式,會返回報錯。 select dateadd('2021-08-27',1,'dd'); --如下輸入參數為STRING類型,符合DATETIME類型格式,且MaxCompute專案的資料類型版本為1.0,返回2005-03-01 00:00:00。 set odps.sql.type.system.odps2=false; select dateadd('2005-02-28 00:00:00', 1, 'dd');
表資料樣本
基於樣本資料,對date1、datetime1和timestamp1列按照指定單位和幅度變化,命令樣本如下。
--開啟2.0新類型。此命令需要與SQL語句一起提交。 set odps.sql.type.system.odps2=true; select date1, dateadd(date1,1,'dd') as date1_dateadd, datetime1, dateadd(datetime1,1,'mm') as datetime1_dateadd, timestamp1, dateadd(timestamp1,-1,'yyyy') as timestamp1_dateadd from mf_date_fun_t;
返回結果如下。
+------------+---------------+---------------------+---------------------+-------------------------------+-------------------------------+ | date1 | date1_dateadd | datetime1 | datetime1_dateadd | timestamp1 | timestamp1_dateadd | +------------+---------------+---------------------+---------------------+-------------------------------+-------------------------------+ | 2021-11-29 | 2021-11-30 | 2021-11-29 00:01:00 | 2021-12-29 00:01:00 | 2021-01-11 00:00:00.123456789 | 2020-01-11 00:00:00.123456789 | | 2021-11-28 | 2021-11-29 | 2021-11-28 00:02:00 | 2021-12-28 00:02:00 | 2021-02-11 00:00:00.123456789 | 2020-02-11 00:00:00.123456789 | | 2021-11-27 | 2021-11-28 | 2021-11-27 00:03:00 | 2021-12-27 00:03:00 | 2021-03-11 00:00:00.123456789 | 2020-03-11 00:00:00.123456789 | | 2021-11-26 | 2021-11-27 | 2021-11-26 00:04:00 | 2021-12-26 00:04:00 | 2021-04-11 00:00:00.123456789 | 2020-04-11 00:00:00.123456789 | | 2021-11-25 | 2021-11-26 | 2021-11-25 00:05:00 | 2021-12-25 00:05:00 | 2021-05-11 00:00:00.123456789 | 2020-05-11 00:00:00.123456789 | | 2021-11-24 | 2021-11-25 | 2021-11-24 00:06:00 | 2021-12-24 00:06:00 | 2021-06-11 00:00:00.123456789 | 2020-06-11 00:00:00.123456789 | | 2021-11-23 | 2021-11-24 | 2021-11-23 00:07:00 | 2021-12-23 00:07:00 | 2021-07-11 00:00:00.123456789 | 2020-07-11 00:00:00.123456789 | | 2021-11-22 | 2021-11-23 | 2021-11-22 00:08:00 | 2021-12-22 00:08:00 | 2021-08-11 00:00:00.123456789 | 2020-08-11 00:00:00.123456789 | | 2021-11-21 | 2021-11-22 | 2021-11-21 00:09:00 | 2021-12-21 00:09:00 | 2021-09-11 00:00:00.123456789 | 2020-09-11 00:00:00.123456789 | | 2021-11-20 | 2021-11-21 | 2021-11-20 00:10:00 | 2021-12-20 00:10:00 | 2021-10-11 00:00:00.123456789 | 2020-10-11 00:00:00.123456789 | +------------+---------------+---------------------+---------------------+-------------------------------+-------------------------------+
DATE_FORMAT
命令格式
string date_format(date|timestamp|string <date>, string <format>)
命令說明
將date按照format指定的格式轉換為字串。
參數說明
date:必填。待轉換的日期值。支援DATE、TIMESTAMP或STRING類型。
DATE和STRING類型只能在Hive相容模式下使用,您可以執行
set odps.sql.hive.compatible=true;
命令開啟Hive模式。如果參數為STRING類型,則格式只支援以下三種日期欄位:
'yyyy-MM-dd'
,例如'2019-12-27'
。'yyyy-MM-dd hh:mm:ss'
,例如'2019-12-27 12:23:10'
。'yyyy-MM-dd hh:mm:ss.SSS'
,例如'2019-12-27 12:23:10.123'
。
format:必填。STRING類型常量。format可由如下日期欄位組成,例如
yyyy-MM-dd hh:mm:ss:SSS
或yyyy-MM-dd hh:mi:ss:SSS
:YYYY
或yyyy
代表年份,其中yyyy代表為日曆年度,YYYY代表為周年。說明周年格式可能會與實際年份不一致,請謹慎使用。
MM
代表月份。mm
代表分鐘。dd
代表天。HH
代表24小時制時。hh
代表12小時制時。mi
代表分鐘。ss
代表秒。SSS
代表毫秒。
重要在非Hive相容模式下,
HH
和hh
都代表24小時制時。並且只能使用yyyy-MM-dd hh:mi:ss
,如果使用yyyy-MM-dd hh:mm:ss
,mm
部分會取月份值。在Hive相容模式下,
HH
代表24小時制時,hh
代表12小時制時。並且只能使用yyyy-MM-dd hh:mm:ss
,如果使用yyyy-MM-dd hh:mi:ss
會返回NULL。
傳回值說明
返回STRING類型。返回規則如下:
date非DATE或TIMESTAMP類型時,返回NULL。
date值為NULL時,返回報錯。
format值為NULL時,返回NULL。
樣本
待用資料樣本
--開啟Hive模式。與SQL語句一起提交。 set odps.sql.hive.compatible=true; --假設目前時間為2022-04-24 15:49。返回2022-04-24 03:49:01.902。 select date_format(from_utc_timestamp(current_timestamp(), 'UTC'),'yyyy-MM-dd hh:mm:ss.SSS'); --返回2022-04-24。 select date_format('2022-04-24','yyyy-MM-dd');
表資料樣本
基於樣本資料,對datetime1和timestamp1轉換為指定格式的字串,命令樣本如下。
--開啟Hive模式並開啟2.0新類型。與SQL語句一起提交。 set odps.sql.hive.compatible=true; set odps.sql.type.system.odps2=true; select datetime1, timestamp1, date_format(datetime1,'yyyy/MM/dd'), date_format(datetime1,'yyyy/MM/dd HH:mm:ss'), date_format(timestamp1,'yyyy/MM/dd HH:mm:ss') from mf_date_fun_t;
返回結果如下。
+------------+------------+-----+-----+-----+ | datetime1 | timestamp1 | _c2 | _c3 | _c4 | +------------+------------+-----+-----+-----+ | 2021-11-29 00:01:00 | 2021-01-11 00:00:00.123456789 | 2021/11/29 | 2021/11/29 00:01:00 | 2021/01/11 00:00:00 | | 2021-11-28 00:02:00 | 2021-02-11 00:00:00.123456789 | 2021/11/28 | 2021/11/28 00:02:00 | 2021/02/11 00:00:00 | | 2021-11-27 00:03:00 | 2021-03-11 00:00:00.123456789 | 2021/11/27 | 2021/11/27 00:03:00 | 2021/03/11 00:00:00 | | 2021-11-26 00:04:00 | 2021-04-11 00:00:00.123456789 | 2021/11/26 | 2021/11/26 00:04:00 | 2021/04/11 00:00:00 | | 2021-11-25 00:05:00 | 2021-05-11 00:00:00.123456789 | 2021/11/25 | 2021/11/25 00:05:00 | 2021/05/11 00:00:00 | | 2021-11-24 00:06:00 | 2021-06-11 00:00:00.123456789 | 2021/11/24 | 2021/11/24 00:06:00 | 2021/06/11 00:00:00 | | 2021-11-23 00:07:00 | 2021-07-11 00:00:00.123456789 | 2021/11/23 | 2021/11/23 00:07:00 | 2021/07/11 00:00:00 | | 2021-11-22 00:08:00 | 2021-08-11 00:00:00.123456789 | 2021/11/22 | 2021/11/22 00:08:00 | 2021/08/11 00:00:00 | | 2021-11-21 00:09:00 | 2021-09-11 00:00:00.123456789 | 2021/11/21 | 2021/11/21 00:09:00 | 2021/09/11 00:00:00 | | 2021-11-20 00:10:00 | 2021-10-11 00:00:00.123456789 | 2021/11/20 | 2021/11/20 00:10:00 | 2021/10/11 00:00:00 | +------------+------------+-----+-----+-----+
DATE_SUB
命令格式
date date_sub(date|timestamp|string <startdate>, bigint <delta>)
命令說明
按照delta幅度增減startdate日期的天數。如果您需要擷取在目前時間基礎上指定變動幅度的日期,請結合GETDATE函數使用。
本命令與DATE_ADD的增減邏輯相反。
參數說明
startdate:必填。起始日期值。支援DATE、DATETIME或STRING類型。
如果參數為STRING類型,且MaxCompute專案的資料類型版本是1.0,則會隱式轉換為DATE類型後參與運算,且STRING參數格式至少要包含
'yyyy-mm-dd'
。例如'2019-12-27'
。delta:必填。修改幅度。BIGINT類型。如果delta大於0,則減;delta小於0,則增;delta等於0,不增不減。
傳回值說明
返回DATE類型,格式為
yyyy-mm-dd
。返回規則如下:startdate非DATE、DATETIME或STRING類型時,返回報錯。
startdate值為NULL時,返回報錯。
delta值為NULL時,返回NULL。
樣本
待用資料樣本
--開啟2.0新類型。此命令需要與SQL語句一起提交。 set odps.sql.type.system.odps2=true; --返回2005-02-28。減1天,實際值為上個月的最後1天。 select date_sub(datetime '2005-03-01 00:00:00', 1); --返回2005-03-01。增1天。 select date_sub(date '2005-02-28', -1); --返回2005-02-27。減2天。 set odps.sql.type.system.odps2=false; select date_sub('2005-03-01 00:00:00', 2); --假設目前時間為2021-09-10 16:31:44,返回2021-09-09。 select date_sub(getdate(),1); --返回NULL。 select date_sub('2005-03-01 00:00:00', null);
表資料樣本
基於樣本資料,對date1、datetime1和timestamp1列按照幅度變化天數,命令樣本如下。
--開啟2.0新類型。此命令需要與SQL語句一起提交。 set odps.sql.type.system.odps2=true; select date1, date_sub(date1,1) as date1_date_sub, datetime1, date_sub(datetime1,-1) as datetime1_date_sub, timestamp1, date_sub(timestamp1,0) as timestamp1_date_sub from mf_date_fun_t;
返回結果如下。
+------------+----------------+---------------------+--------------------+-------------------------------+---------------------+ | date1 | date1_date_sub | datetime1 | datetime1_date_sub | timestamp1 | timestamp1_date_sub | +------------+----------------+---------------------+--------------------+-------------------------------+---------------------+ | 2021-11-29 | 2021-11-28 | 2021-11-29 00:01:00 | 2021-11-30 | 2021-01-11 00:00:00.123456789 | 2021-01-11 | | 2021-11-28 | 2021-11-27 | 2021-11-28 00:02:00 | 2021-11-29 | 2021-02-11 00:00:00.123456789 | 2021-02-11 | | 2021-11-27 | 2021-11-26 | 2021-11-27 00:03:00 | 2021-11-28 | 2021-03-11 00:00:00.123456789 | 2021-03-11 | | 2021-11-26 | 2021-11-25 | 2021-11-26 00:04:00 | 2021-11-27 | 2021-04-11 00:00:00.123456789 | 2021-04-11 | | 2021-11-25 | 2021-11-24 | 2021-11-25 00:05:00 | 2021-11-26 | 2021-05-11 00:00:00.123456789 | 2021-05-11 | | 2021-11-24 | 2021-11-23 | 2021-11-24 00:06:00 | 2021-11-25 | 2021-06-11 00:00:00.123456789 | 2021-06-11 | | 2021-11-23 | 2021-11-22 | 2021-11-23 00:07:00 | 2021-11-24 | 2021-07-11 00:00:00.123456789 | 2021-07-11 | | 2021-11-22 | 2021-11-21 | 2021-11-22 00:08:00 | 2021-11-23 | 2021-08-11 00:00:00.123456789 | 2021-08-11 | | 2021-11-21 | 2021-11-20 | 2021-11-21 00:09:00 | 2021-11-22 | 2021-09-11 00:00:00.123456789 | 2021-09-11 | | 2021-11-20 | 2021-11-19 | 2021-11-20 00:10:00 | 2021-11-21 | 2021-10-11 00:00:00.123456789 | 2021-10-11 | +------------+----------------+---------------------+--------------------+-------------------------------+---------------------+
DATEDIFF
命令格式
bigint datediff(date|datetime|timestamp <date1>, date|datetime|timestamp <date2>, string <datepart>)
命令說明
計算兩個時間date1、date2的差值,將差值以指定的時間單位datepart表示。
參數說明
date1、date2:必填。DATE、DATETIME或TIMESTAMP類型。被減數和減數。
如果輸入為STRING類型,且MaxCompute專案的資料類型版本是1.0,則會隱式轉換為DATETIME類型後參與運算。
說明MaxCompute資料類型版本2.0才支援TIMESTAMP類型。關於2.0資料類型版本詳情,請參見2.0資料類型版本。
datepart:可選。時間單位,STRING類型常量。
如果您開啟了MaxCompute新資料類型開關,可以不填寫datepart參數,預設日期格式為天。該欄位也支援擴充的日期格式:年
-year
、月-month
或-mon
、日-day
和小時-hour
。說明系統計算時會按照datepart切掉低單位部分,然後再計算結果。
傳回值說明
返回BIGINT類型。返回規則如下:
date1、date2非DATE、DATETIME或TIMESTAMP類型時,返回報錯。
如果date1小於date2,傳回值為負數。
date1或date2值為NULL時,返回NULL。
datepart值為NULL時,返回NULL。
樣本
待用資料樣本
樣本1
SET odps.sql.type.system.odps2=true; SELECT DATEDIFF(TIMESTAMP '2006-01-01 00:00:00', TIMESTAMP '2005-12-31 23:59:59', 'dd');
返回結果如下。
+------------+ | _c0 | +------------+ | 1 | +------------+
樣本2
SET odps.sql.type.system.odps2=true; SELECT DATEDIFF(TIMESTAMP '2006-01-01 00:00:00', TIMESTAMP '2005-12-31 23:59:59', 'mm');
返回結果如下。
+------------+ | _c0 | +------------+ | 1 | +------------+
樣本3
SELECT DATEDIFF(DATETIME '2013-05-31 13:00:00', DATETIME '2013-05-31 12:30:00','ss');
返回結果如下。
+------------+ | _c0 | +------------+ | 1800 | +------------+
樣本4
SET odps.sql.type.system.odps2 = false; SELECT DATEDIFF('2013-05-31 13:00:00','2013-05-31 12:30:00','mi');
返回結果如下。
+------------+ | _c0 | +------------+ | 30 | +------------+
樣本5
--含毫秒的日期不屬於標準DATETIME式樣,不能直接隱式轉換,此處需進行顯示轉換 SELECT DATEDIFF(TO_DATE('2018-06-04 19:33:23.250','yyyy-mm-dd hh:mi:ss.ff3'),TO_DATE('2018-06-04 19:33:23.234','yyyy-mm-dd hh:mi:ss.ff3'),'ff3');
返回結果如下。
+------------+ | _c0 | +------------+ | 16 | +------------+
樣本6
SET odps.sql.type.system.odps2=true; SELECT DATEDIFF(DATE '2013-05-21',DATE '2013-05-10',NULL);
返回結果如下。
+------------+ | _c0 | +------------+ | NULL | +------------+
表資料樣本
基於樣本資料,計算date1和date2、datetime1和datetime2、timestamp1和timestamp2列的差值,並以指定單位表示,命令樣本如下。
--開啟2.0新類型。此命令需要與SQL語句一起提交。 SET odps.sql.type.system.odps2 = true; SELECT date1 ,date2 ,DATEDIFF(date1,date2,'dd') AS date1_date2_datediff ,datetime1 ,datetime2 ,DATEDIFF(datetime1,datetime2,'dd') AS datetime1_datetime2_datediff ,timestamp1 ,timestamp2 ,DATEDIFF(timestamp1,timestamp2,'mm') AS timestamp1_timestamp2_datediff FROM mf_date_fun_t;
返回結果如下。
+------------+------------+----------------------+---------------------+---------------------+------------------------------+-------------------------------+-------------------------------+--------------------------------+ | date1 | date2 | date1_date2_datediff | datetime1 | datetime2 | datetime1_datetime2_datediff | timestamp1 | timestamp2 | timestamp1_timestamp2_datediff | +------------+------------+----------------------+---------------------+---------------------+------------------------------+-------------------------------+-------------------------------+--------------------------------+ | 2021-11-29 | 2021-10-29 | 31 | 2021-11-29 00:01:00 | 2021-10-29 00:00:00 | 31 | 2021-01-11 00:00:00.123456789 | 2021-10-11 00:00:00.123456789 | -9 | | 2021-11-28 | 2021-10-29 | 30 | 2021-11-28 00:02:00 | 2021-10-29 00:00:00 | 30 | 2021-02-11 00:00:00.123456789 | 2021-10-11 00:00:00.123456789 | -8 | | 2021-11-27 | 2021-10-29 | 29 | 2021-11-27 00:03:00 | 2021-10-29 00:00:00 | 29 | 2021-03-11 00:00:00.123456789 | 2021-10-11 00:00:00.123456789 | -7 | | 2021-11-26 | 2021-10-29 | 28 | 2021-11-26 00:04:00 | 2021-10-29 00:00:00 | 28 | 2021-04-11 00:00:00.123456789 | 2021-10-11 00:00:00.123456789 | -6 | | 2021-11-25 | 2021-10-29 | 27 | 2021-11-25 00:05:00 | 2021-10-29 00:00:00 | 27 | 2021-05-11 00:00:00.123456789 | 2021-10-11 00:00:00.123456789 | -5 | | 2021-11-24 | 2021-10-29 | 26 | 2021-11-24 00:06:00 | 2021-10-29 00:00:00 | 26 | 2021-06-11 00:00:00.123456789 | 2021-10-11 00:00:00.123456789 | -4 | | 2021-11-23 | 2021-10-29 | 25 | 2021-11-23 00:07:00 | 2021-10-29 00:00:00 | 25 | 2021-07-11 00:00:00.123456789 | 2021-10-11 00:00:00.123456789 | -3 | | 2021-11-22 | 2021-10-29 | 24 | 2021-11-22 00:08:00 | 2021-10-29 00:00:00 | 24 | 2021-08-11 00:00:00.123456789 | 2021-10-11 00:00:00.123456789 | -2 | | 2021-11-21 | 2021-10-29 | 23 | 2021-11-21 00:09:00 | 2021-10-29 00:00:00 | 23 | 2021-09-11 00:00:00.123456789 | 2021-10-11 00:00:00.123456789 | -1 | | 2021-11-20 | 2021-10-29 | 22 | 2021-11-20 00:10:00 | 2021-10-29 00:00:00 | 22 | 2021-10-11 00:00:00.123456789 | 2021-10-11 00:00:00.123456789 | 0 | +------------+------------+----------------------+---------------------+---------------------+------------------------------+-------------------------------+-------------------------------+--------------------------------+
DATEPART
命令格式
bigint datepart(date|datetime|timestamp <date>, string <datepart>)
命令說明
提取日期date中符合指定時間單位datepart的值。
參數說明
date:必填。DATE、DATETIME或TIMESTAMP類型。如果輸入為STRING類型,且MaxCompute專案的資料類型版本是1.0,則會隱式轉換為DATETIME類型後參與運算。
datepart:必填。STRING類型常量,支援擴充的日期格式。
此欄位的取值遵循STRING與DATETIME類型轉換的約定,即
yyyy
表示年,mm
表示月,dd
表示天。關於類型轉換的規則,詳情請參見資料類型轉換。該欄位也支援擴充的日期格式:年-year
、月-month
或-mon
、日-day
和小時-hour
。
傳回值說明
返回BIGINT類型。返回規則如下:
date非DATE、DATETIME或TIMESTAMP類型時,返回報錯。
date值為NULL時,返回報錯。
datepart值為NULL時,返回NULL。
樣本
待用資料樣本
--返回2013。 select datepart(datetime'2013-06-08 01:10:00', 'yyyy'); --返回6。 select datepart(datetime'2013-06-08 01:10:00', 'mm'); --返回2013。 select datepart(date '2013-06-08', 'yyyy'); --開啟2.0新類型。此命令需要與SQL語句一起提交。返回2013。 set odps.sql.type.system.odps2=true; select datepart(timestamp '2013-06-08 01:10:00', 'yyyy'); --返回2013。 set odps.sql.type.system.odps2=false; select datepart('2013-06-08 01:10:00', 'yyyy'); --返回NULL。 select datepart(date '2013-06-08', null);
表資料樣本
基於樣本資料,提取date1、datetime1和timestamp1中符合指定時間單位的值,命令樣本如下。
--開啟2.0新類型。此命令需要與SQL語句一起提交。 set odps.sql.type.system.odps2=true; select date1, datepart(date1,'yyyy') as date1_datepart, datetime1, datepart(datetime1,'dd') as datetime1_datepart, timestamp1, datepart(timestamp1,'mm') as timestamp1_datepart from mf_date_fun_t;
返回結果如下。
+------------+----------------+---------------------+-------------------------+-------------------------------+---------------------+ | date1 | date1_datepart | datetime1 | datetime1_datepart | timestamp1 | timestamp1_datepart | +------------+----------------+---------------------+-------------------------+-------------------------------+---------------------+ | 2021-11-29 | 2021 | 2021-11-29 00:01:00 | 29 | 2021-01-11 00:00:00.123456789 | 1 | | 2021-11-28 | 2021 | 2021-11-28 00:02:00 | 28 | 2021-02-11 00:00:00.123456789 | 2 | | 2021-11-27 | 2021 | 2021-11-27 00:03:00 | 27 | 2021-03-11 00:00:00.123456789 | 3 | | 2021-11-26 | 2021 | 2021-11-26 00:04:00 | 26 | 2021-04-11 00:00:00.123456789 | 4 | | 2021-11-25 | 2021 | 2021-11-25 00:05:00 | 25 | 2021-05-11 00:00:00.123456789 | 5 | | 2021-11-24 | 2021 | 2021-11-24 00:06:00 | 24 | 2021-06-11 00:00:00.123456789 | 6 | | 2021-11-23 | 2021 | 2021-11-23 00:07:00 | 23 | 2021-07-11 00:00:00.123456789 | 7 | | 2021-11-22 | 2021 | 2021-11-22 00:08:00 | 22 | 2021-08-11 00:00:00.123456789 | 8 | | 2021-11-21 | 2021 | 2021-11-21 00:09:00 | 21 | 2021-09-11 00:00:00.123456789 | 9 | | 2021-11-20 | 2021 | 2021-11-20 00:10:00 | 20 | 2021-10-11 00:00:00.123456789 | 10 | +------------+----------------+---------------------+-------------------------+-------------------------------+---------------------+
DATETRUNC
命令格式
date|datetime datetrunc (date|datetime|timestamp <date>, string <datepart>)
命令說明
返回將日期date按照datepart指定的時間單位進行截取後的日期值。
參數說明
date:必填。DATE、DATETIME或TIMESTAMP類型。如果輸入為STRING類型,且MaxCompute專案的資料類型版本是1.0,則會隱式轉換為DATETIME類型後參與運算。
datepart:必填。STRING類型常量。支援擴充的日期格式。
此欄位的取值遵循STRING與DATETIME類型轉換的約定,即
yyyy
表示年,mm
表示月,dd
表示天。關於類型轉換的規則,詳情請參見資料類型轉換。該欄位也支援擴充的日期格式:年-year
、月-month
或-mon
、日-day
和小時-hour
。
傳回值說明
返回DATE或DATETIME類型,格式為
yyyy-mm-dd
或yyyy-mm-dd hh:mi:ss
。返回規則如下:date非DATE、DATETIME或TIMESTAMP類型時,返回報錯。
date值為NULL時,返回報錯。
datepart值為NULL時,返回NULL。
樣本
待用資料樣本
--返回2011-01-01 00:00:00。 select datetrunc(datetime'2011-12-07 16:28:46', 'yyyy'); --返回2011-12-01 00:00:00。 select datetrunc(datetime'2011-12-07 16:28:46', 'month'); --返回2011-12-07 00:00:00。 select datetrunc(datetime'2011-12-07 16:28:46', 'DD'); --返回2011-01-01。 select datetrunc(date '2011-12-07', 'yyyy'); --開啟2.0新類型。此命令需要與SQL語句一起提交。返回2011-01-01 00:00:00.0。 set odps.sql.type.system.odps2=true; select datetrunc(timestamp '2011-12-07 16:28:46', 'yyyy'); --返回2011-01-01 00:00:00.0。 set odps.sql.type.system.odps2=false; select datetrunc('2011-12-07 16:28:46', 'yyyy'); --返回NULL。 select datetrunc(date '2011-12-07', null);
表資料樣本
基於樣本資料,返回date1、datetime1和timestamp1按照指定時間單位截取後的值,命令樣本如下。
--開啟2.0新類型。此命令需要與SQL語句一起提交。 set odps.sql.type.system.odps2=true; select date1, datetrunc(date1,'yyyy') as date1_datetrunc, datetime1, datetrunc(datetime1,'dd') as datetime1_datetrunc, timestamp1, datetrunc(timestamp1,'mm') as timestamp1_datetrunc from mf_date_fun_t;
返回結果如下。
+------------+-----------------+---------------------+---------------------+-------------------------------+----------------------+ | date1 | date1_datetrunc | datetime1 | datetime1_datetrunc | timestamp1 | timestamp1_datetrunc | +------------+-----------------+---------------------+---------------------+-------------------------------+----------------------+ | 2021-11-29 | 2021-01-01 | 2021-11-29 00:01:00 | 2021-11-29 00:00:00 | 2021-01-11 00:00:00.123456789 | 2021-01-01 00:00:00 | | 2021-11-28 | 2021-01-01 | 2021-11-28 00:02:00 | 2021-11-28 00:00:00 | 2021-02-11 00:00:00.123456789 | 2021-02-01 00:00:00 | | 2021-11-27 | 2021-01-01 | 2021-11-27 00:03:00 | 2021-11-27 00:00:00 | 2021-03-11 00:00:00.123456789 | 2021-03-01 00:00:00 | | 2021-11-26 | 2021-01-01 | 2021-11-26 00:04:00 | 2021-11-26 00:00:00 | 2021-04-11 00:00:00.123456789 | 2021-04-01 00:00:00 | | 2021-11-25 | 2021-01-01 | 2021-11-25 00:05:00 | 2021-11-25 00:00:00 | 2021-05-11 00:00:00.123456789 | 2021-05-01 00:00:00 | | 2021-11-24 | 2021-01-01 | 2021-11-24 00:06:00 | 2021-11-24 00:00:00 | 2021-06-11 00:00:00.123456789 | 2021-06-01 00:00:00 | | 2021-11-23 | 2021-01-01 | 2021-11-23 00:07:00 | 2021-11-23 00:00:00 | 2021-07-11 00:00:00.123456789 | 2021-07-01 00:00:00 | | 2021-11-22 | 2021-01-01 | 2021-11-22 00:08:00 | 2021-11-22 00:00:00 | 2021-08-11 00:00:00.123456789 | 2021-08-01 00:00:00 | | 2021-11-21 | 2021-01-01 | 2021-11-21 00:09:00 | 2021-11-21 00:00:00 | 2021-09-11 00:00:00.123456789 | 2021-09-01 00:00:00 | | 2021-11-20 | 2021-01-01 | 2021-11-20 00:10:00 | 2021-11-20 00:00:00 | 2021-10-11 00:00:00.123456789 | 2021-10-01 00:00:00 | +------------+-----------------+---------------------+---------------------+-------------------------------+----------------------+
DAY
命令格式
int day(datetime|timestamp|date|string <date>)
命令說明
返回一個日期的天。此函數為MaxCompute 2.0擴充函數。
參數說明
date:必填。DATETIME、TIMESTAMP、DATE或STRING類型日期值,格式為
yyyy-mm-dd
、yyyy-mm-dd hh:mi:ss
或yyyy-mm-dd hh:mi:ss.ff3
。取值為STRING類型格式時,至少要包含yyyy-mm-dd
且不含多餘的字串。傳回值說明
返回INT類型。返回規則如下:
date非DATETIME、TIMESTAMP、DATE或STRING類型,或格式不符合要求時,返回NULL。
date值為NULL時,返回NULL。
樣本
待用資料樣本
--返回1。 select day('2014-09-01'); --返回NULL。 select day('20140901'); --返回NULL。 select day(null);
表資料樣本
基於樣本資料,返回date1、datetime1、timestamp1和date3列日期對應的天,命令樣本如下。
--開啟2.0新類型。此命令需要與SQL語句一起提交。 set odps.sql.type.system.odps2=true; select date1, day(date1) as date1_day, datetime1, day(datetime1) as datetime1_day, timestamp1, day(timestamp1) as timestamp1_day, date3, day(date3) as date3_day from mf_date_fun_t;
返回結果如下。
+------------+-----------+---------------------+---------------+-------------------------------+----------------+------------+-----------+ | date1 | date1_day | datetime1 | datetime1_day | timestamp1 | timestamp1_day | date3 | date3_day | +------------+-----------+---------------------+---------------+-------------------------------+----------------+------------+-----------+ | 2021-11-29 | 29 | 2021-11-29 00:01:00 | 29 | 2021-01-11 00:00:00.123456789 | 11 | 2021-11-20 | 20 | | 2021-11-28 | 28 | 2021-11-28 00:02:00 | 28 | 2021-02-11 00:00:00.123456789 | 11 | 2021-11-21 | 21 | | 2021-11-27 | 27 | 2021-11-27 00:03:00 | 27 | 2021-03-11 00:00:00.123456789 | 11 | 2021-11-22 | 22 | | 2021-11-26 | 26 | 2021-11-26 00:04:00 | 26 | 2021-04-11 00:00:00.123456789 | 11 | 2021-11-23 | 23 | | 2021-11-25 | 25 | 2021-11-25 00:05:00 | 25 | 2021-05-11 00:00:00.123456789 | 11 | 2021-11-24 | 24 | | 2021-11-24 | 24 | 2021-11-24 00:06:00 | 24 | 2021-06-11 00:00:00.123456789 | 11 | 2021-11-25 | 25 | | 2021-11-23 | 23 | 2021-11-23 00:07:00 | 23 | 2021-07-11 00:00:00.123456789 | 11 | 2021-11-26 | 26 | | 2021-11-22 | 22 | 2021-11-22 00:08:00 | 22 | 2021-08-11 00:00:00.123456789 | 11 | 2021-11-27 | 27 | | 2021-11-21 | 21 | 2021-11-21 00:09:00 | 21 | 2021-09-11 00:00:00.123456789 | 11 | 2021-11-28 | 28 | | 2021-11-20 | 20 | 2021-11-20 00:10:00 | 20 | 2021-10-11 00:00:00.123456789 | 11 | 2021-11-29 | 29 | +------------+-----------+---------------------+---------------+-------------------------------+----------------+------------+-----------+
DAYOFMONTH
命令格式
int dayofmonth(datetime|timestamp|date|string <date>)
命令說明
返回日期日部分的值。此函數為MaxCompute 2.0擴充函數。
參數說明
date:必填。DATETIME、TIMESTAMP、DATE或STRING類型日期值,格式為
yyyy-mm-dd
、yyyy-mm-dd hh:mi:ss
或yyyy-mm-dd hh:mi:ss.ff3
。取值為STRING類型格式時,至少要包含yyyy-mm-dd
且不含多餘的字串。傳回值說明
返回INT類型。返回規則如下:
date非DATETIME、TIMESTAMP、DATE或STRING類型,或格式不符合要求時,返回NULL。
date值為NULL時,返回NULL。
樣本
待用資料樣本
--返回1。 select dayofmonth('2014-09-01'); --返回NULL。 select dayofmonth('20140901'); --返回NULL。 select dayofmonth(null);
表資料樣本
基於樣本資料,返回date1、datetime1、timestamp1和date3列日期日部分的值,命令樣本如下。
--開啟2.0新類型。此命令需要與SQL語句一起提交。 set odps.sql.type.system.odps2=true; select date1, dayofmonth(date1) as date1_dayofmonth, datetime1, dayofmonth(datetime1) as datetime1_dayofmonth, timestamp1, dayofmonth(timestamp1) as timestamp1_dayofmonth, date3, dayofmonth(date3) as date3_dayofmonth from mf_date_fun_t;
返回結果如下。
+------------+------------------+---------------------+----------------------+-------------------------------+-----------------------+------------+------------------+ | date1 | date1_dayofmonth | datetime1 | datetime1_dayofmonth | timestamp1 | timestamp1_dayofmonth | date3 | date3_dayofmonth | +------------+------------------+---------------------+----------------------+-------------------------------+-----------------------+------------+------------------+ | 2021-11-29 | 29 | 2021-11-29 00:01:00 | 29 | 2021-01-11 00:00:00.123456789 | 11 | 2021-11-20 | 20 | | 2021-11-28 | 28 | 2021-11-28 00:02:00 | 28 | 2021-02-11 00:00:00.123456789 | 11 | 2021-11-21 | 21 | | 2021-11-27 | 27 | 2021-11-27 00:03:00 | 27 | 2021-03-11 00:00:00.123456789 | 11 | 2021-11-22 | 22 | | 2021-11-26 | 26 | 2021-11-26 00:04:00 | 26 | 2021-04-11 00:00:00.123456789 | 11 | 2021-11-23 | 23 | | 2021-11-25 | 25 | 2021-11-25 00:05:00 | 25 | 2021-05-11 00:00:00.123456789 | 11 | 2021-11-24 | 24 | | 2021-11-24 | 24 | 2021-11-24 00:06:00 | 24 | 2021-06-11 00:00:00.123456789 | 11 | 2021-11-25 | 25 | | 2021-11-23 | 23 | 2021-11-23 00:07:00 | 23 | 2021-07-11 00:00:00.123456789 | 11 | 2021-11-26 | 26 | | 2021-11-22 | 22 | 2021-11-22 00:08:00 | 22 | 2021-08-11 00:00:00.123456789 | 11 | 2021-11-27 | 27 | | 2021-11-21 | 21 | 2021-11-21 00:09:00 | 21 | 2021-09-11 00:00:00.123456789 | 11 | 2021-11-28 | 28 | | 2021-11-20 | 20 | 2021-11-20 00:10:00 | 20 | 2021-10-11 00:00:00.123456789 | 11 | 2021-11-29 | 29 | +------------+------------------+---------------------+----------------------+-------------------------------+-----------------------+------------+------------------+
DAYOFWEEK
命令格式
int dayofweek(datetime|timestamp|date|string <date>)
命令說明
返回日期的星期值。此函數為MaxCompute 2.0擴充函數。
參數說明
date:必填。DATETIME、TIMESTAMP、DATE或STRING類型日期值,格式為
yyyy-mm-dd
、yyyy-mm-dd hh:mi:ss
或yyyy-mm-dd hh:mi:ss.ff3
。取值為STRING類型格式時,至少要包含yyyy-mm-dd
且不含多餘的字串。傳回值說明
返回INT類型。返回規則如下:
date非DATETIME、TIMESTAMP、DATE或STRING類型,或格式不符合要求時,返回NULL。
date值為NULL時,返回NULL。
傳回值的取值範圍為1~7,與星期的對應關係為1=Sunday, 2=Monday,...,7=Saturday。
樣本
--返回5,即Thursday。 SELECT dayofweek('2009-07-30');
DAYOFYEAR
命令格式
int dayofyear(datetime|timestamp|date|string <date>)
命令說明
返回日期是當年中的第幾天。此函數為MaxCompute 2.0擴充函數。
參數說明
date:必填。DATETIME、TIMESTAMP、DATE或STRING類型日期值,格式為
yyyy-mm-dd
、yyyy-mm-dd hh:mi:ss
或yyyy-mm-dd hh:mi:ss.ff3
。取值為STRING類型格式時,至少要包含yyyy-mm-dd
且不含多餘的字串。傳回值說明
返回INT類型。返回規則如下:
date非DATETIME、TIMESTAMP、DATE或STRING類型,或格式不符合要求時,返回NULL。
date值為NULL時,返回NULL。
樣本
--返回100。 SELECT dayofyear('2016-04-09');
EXTRACT
命令格式
int extract(<datepart> from date|datetime|timestamp <date>)
命令說明
提取日期date中指定單位datepart的部分。此函數為MaxCompute 2.0擴充函數。
參數說明
datepart:必填。支援YEAR、MONTH、DAY、HOUR或MINUTE等時間取值。
date:必填。DATE、DATETIME、TIMESTAMP或STRING類型日期值,格式為
yyyy-mm-dd
、yyyy-mm-dd hh:mi:ss
或yyyy-mm-dd hh:mi:ss.ff3
。取值為STRING類型格式時,至少要包含yyyy-mm-dd
且不含多餘的字串。
傳回值
返回INT類型。返回規則如下:
datepart非YEAR、MONTH、DAY、HOUR或MINUTE等時間取值時,返回報錯。
datepart值為NULL時,返回報錯。
date非DATE、DATETIME、TIMESTAMP或STRING類型或為NULL時,返回NULL。
樣本
待用資料樣本
--開啟2.0新類型。此命令需要與SQL語句一起提交。 set odps.sql.type.system.odps2=true; select extract(year from '2019-05-01 11:21:00') year ,extract(month from '2019-05-01 11:21:00') month ,extract(day from '2019-05-01 11:21:00') day ,extract(hour from '2019-05-01 11:21:00') hour ,extract(minute from '2019-05-01 11:21:00') minute; --傳回值如下。 +------+-------+------+------+--------+ | year | month | day | hour | minute | +------+-------+------+------+--------+ | 2019 | 5 | 1 | 11 | 21 | +------+-------+------+------+--------+ --返回NULL。 select extract(year from null);
表資料樣本
基於樣本資料,提取timestamp1列的指定部分,命令樣本如下。
--開啟2.0新類型。此命令需要與SQL語句一起提交。 set odps.sql.type.system.odps2=true; select timestamp1, extract(year from timestamp1) year, timestamp2, extract(month from timestamp2) month from mf_date_fun_t;
返回結果如下。
+-------------------------------+------+-------------------------------+-------+ | timestamp1 | year | timestamp2 | month | +-------------------------------+------+-------------------------------+-------+ | 2021-01-11 00:00:00.123456789 | 2021 | 2021-10-11 00:00:00.123456789 | 10 | | 2021-02-11 00:00:00.123456789 | 2021 | 2021-10-11 00:00:00.123456789 | 10 | | 2021-03-11 00:00:00.123456789 | 2021 | 2021-10-11 00:00:00.123456789 | 10 | | 2021-04-11 00:00:00.123456789 | 2021 | 2021-10-11 00:00:00.123456789 | 10 | | 2021-05-11 00:00:00.123456789 | 2021 | 2021-10-11 00:00:00.123456789 | 10 | | 2021-06-11 00:00:00.123456789 | 2021 | 2021-10-11 00:00:00.123456789 | 10 | | 2021-07-11 00:00:00.123456789 | 2021 | 2021-10-11 00:00:00.123456789 | 10 | | 2021-08-11 00:00:00.123456789 | 2021 | 2021-10-11 00:00:00.123456789 | 10 | | 2021-09-11 00:00:00.123456789 | 2021 | 2021-10-11 00:00:00.123456789 | 10 | | 2021-10-11 00:00:00.123456789 | 2021 | 2021-10-11 00:00:00.123456789 | 10 | +-------------------------------+------+-------------------------------+-------+
FROM_UNIXTIME
命令格式
datetime from_unixtime(bigint <unixtime>)
命令說明
將數字型的UNIX時間日期值unixtime轉為日期值。
參數說明
unixtime:必填。BIGINT類型,秒數,UNIX格式的日期時間值,取值範圍:[-62167305600, 253402387200]。
說明如果輸入為STRING、DOUBLE或DECIMAL類型,且MaxCompute專案的資料類型版本是1.0,則會隱式轉換為BIGINT後參與運算。
傳回值說明
返回DATETIME類型,格式為
yyyy-mm-dd hh:mi:ss
。unixtime值為NULL時,返回NULL。說明Hive相容模式下(
set odps.sql.hive.compatible=true;
):如果輸入參數是STRING類型,傳回值也是STRING類型。
可以傳入第二個參數,來決定輸出的日期時間格式。如果設定格式為“yyyy-MM-dd” 或者“YYYY-MM-dd” ,其中yyyy代表為年,YYYY代表為周年,請謹慎使用周年方式,周年格式可能會與實際年份不一致。
樣本
待用資料樣本
--返回1973-11-30 05:33:09。 select from_unixtime(123456789); --返回1973-11-30 05:33:09。 set odps.sql.type.system.odps2=false; select from_unixtime('123456789'); --返回NULL。 select from_unixtime(null);
表資料樣本
基於樣本資料,將date4轉換為日期值,命令樣本如下。
select date4, from_unixtime(date4) as date4_from_unixtime from mf_date_fun_t;
返回結果如下。
+------------+---------------------+ | date4 | date4_from_unixtime | +------------+---------------------+ | 123456780 | 1973-11-30 05:33:00 | | 123456781 | 1973-11-30 05:33:01 | | 123456782 | 1973-11-30 05:33:02 | | 123456783 | 1973-11-30 05:33:03 | | 123456784 | 1973-11-30 05:33:04 | | 123456785 | 1973-11-30 05:33:05 | | 123456786 | 1973-11-30 05:33:06 | | 123456787 | 1973-11-30 05:33:07 | | 123456788 | 1973-11-30 05:33:08 | | 123456789 | 1973-11-30 05:33:09 | +------------+---------------------+
FROM_UTC_TIMESTAMP
命令格式
timestamp from_utc_timestamp({any primitive type}*, string <timezone>)
命令說明
將一個UTC時區的時間戳記轉換成一個指定時區的時間戳記,即將一個UTC時區的時間戳記按照指定的時區顯示。此函數為MaxCompute 2.0擴充函數。
重要FROM_UTC_TIMESTAMP函數還會受到Project層級flag(
odps.sql.timezone
)配置的影響。假如odps.sql.timezone=Asia/Shanghai
即東八區時區,會比UTC時區多八個小時,所以會在FROM_UTC_TIMESTAMP函數轉換後的基礎上再加八個小時顯示。樣本:FROM_UTC_TIMESTAMP(0, 'Asia/Shanghai')
的邏輯是把UTC-0時區的0,向北京時區位移,得到的是UTC-0時間為0 + 8 * 3600 = 28800
。但由於Project配置了odps.sql.timezone=Asia/Shanghai
,會導致繼續位移八小時,最終顯示為1970-01-01 16:00:00
。參數說明
{any primitive type}*:必填。時間戳記,支援TIMESTAMP、DATETIME、TINYINT、SMALLINT、INT或BIGINT資料類型。如果該參數為TINYINT、SMALLINT、INT或BIGINT資料類型,則單位為毫秒。
timezone:必填。指定需要轉換的目標時區。
說明您可直接在搜尋引擎中尋找相關時區列表詳情。
傳回值說明
返回TIMESTAMP類型,格式為
yyyy-mm-dd hh:mi:ss.ff3
。返回規則如下:{any primitive type}*非TIMESTAMP、DATETIME、TINYINT、SMALLINT、INT或BIGINT時,返回報錯。
{any primitive type}*值為NULL時,返回報錯。
timezone值為NULL時,返回NULL。
樣本
待用資料樣本
--輸入參數為毫秒(ms),返回2017-08-01 04:24:00.0。 select from_utc_timestamp(1501557840000, 'PST'); --返回1970-01-30 08:00:00.0。 select from_utc_timestamp('1970-01-30 16:00:00','PST'); --返回1970-01-29 16:00:00.0。 select from_utc_timestamp('1970-01-30','PST'); --開啟2.0新類型。此命令需要與SQL語句一起提交。返回2011-12-25 17:00:00.123。 set odps.sql.type.system.odps2=true; select from_utc_timestamp(timestamp '2011-12-25 09:00:00.123456', 'Asia/Shanghai'); --開啟2.0新類型。此命令需要與SQL語句一起提交。返回2011-12-25 01:55:00.0。 set odps.sql.type.system.odps2=true; select from_utc_timestamp(timestamp '2011-12-25 06:55:00', 'America/Toronto'); --返回NULL。 select from_utc_timestamp('1970-01-30',null);
表資料樣本
基於樣本資料,將datetime1和timestamp1列轉換為指定時區的時間戳記,命令樣本如下。
--開啟2.0新類型。此命令需要與SQL語句一起提交。 set odps.sql.type.system.odps2=true; select datetime1, from_utc_timestamp(datetime1,'PST') pst, timestamp1, from_utc_timestamp(timestamp1,'Asia/Shanghai') asia from mf_date_fun_t;
返回結果如下。
+---------------------+---------------------+-------------------------------+-------------------------------+ | datetime1 | pst | timestamp1 | asia | +---------------------+---------------------+-------------------------------+-------------------------------+ | 2021-11-29 00:01:00 | 2021-11-28 16:01:00 | 2021-01-11 00:00:00.123456789 | 2021-01-11 08:00:00.123456789 | | 2021-11-28 00:02:00 | 2021-11-27 16:02:00 | 2021-02-11 00:00:00.123456789 | 2021-02-11 08:00:00.123456789 | | 2021-11-27 00:03:00 | 2021-11-26 16:03:00 | 2021-03-11 00:00:00.123456789 | 2021-03-11 08:00:00.123456789 | | 2021-11-26 00:04:00 | 2021-11-25 16:04:00 | 2021-04-11 00:00:00.123456789 | 2021-04-11 08:00:00.123456789 | | 2021-11-25 00:05:00 | 2021-11-24 16:05:00 | 2021-05-11 00:00:00.123456789 | 2021-05-11 08:00:00.123456789 | | 2021-11-24 00:06:00 | 2021-11-23 16:06:00 | 2021-06-11 00:00:00.123456789 | 2021-06-11 08:00:00.123456789 | | 2021-11-23 00:07:00 | 2021-11-22 16:07:00 | 2021-07-11 00:00:00.123456789 | 2021-07-11 08:00:00.123456789 | | 2021-11-22 00:08:00 | 2021-11-21 16:08:00 | 2021-08-11 00:00:00.123456789 | 2021-08-11 08:00:00.123456789 | | 2021-11-21 00:09:00 | 2021-11-20 16:09:00 | 2021-09-11 00:00:00.123456789 | 2021-09-11 08:00:00.123456789 | | 2021-11-20 00:10:00 | 2021-11-19 16:10:00 | 2021-10-11 00:00:00.123456789 | 2021-10-11 08:00:00.123456789 | +---------------------+---------------------+-------------------------------+-------------------------------+
GETDATE
命令格式
datetime getdate()
命令說明
擷取當前系統時間。使用東八區時間作為MaxCompute標準時間。
傳回值說明
返回當前日期和時間,DATETIME類型。
說明在MaxCompute SQL中,
getdate
總是返回一個固定的值。返回結果會是MaxCompute SQL執行期間的任意時間,時間精度精確到秒。如果開啟了新資料類型2.0,時間精度精確到毫秒。
HOUR
命令格式
int hour(datetime|timestamp|string <date>)
命令說明
返回日期小時部分的值。
參數說明
date:必填。DATETIME、TIMESTAMP或STRING類型日期值,格式為
yyyy-mm-dd hh:mi:ss
或yyyy-mm-dd hh:mi:ss.ff3
。取值為STRING類型格式時,至少要包含yyyy-mm-dd
且不含多餘的字串。此函數為MaxCompute 2.0擴充函數。傳回值說明
返回INT類型。返回規則如下:
date非DATETIME、TIMESTAMP或STRING類型,或格式不符合要求時,返回NULL。
date值為NULL時,返回NULL。
樣本
待用資料樣本
--返回12。 select hour('2014-09-01 12:00:00'); --返回12。 select hour('12:00:00'); --返回NULL。 select hour('20140901120000'); --返回NULL。 select hour(null);
表資料樣本
基於樣本資料,返回datetime1和timestamp1小時部分的值,命令樣本如下。
--開啟2.0新類型。此命令需要與SQL語句一起提交。 set odps.sql.type.system.odps2=true; select datetime1, hour(datetime1) as datetime1_hour, timestamp1, hour(timestamp1) as timestamp1_hour from mf_date_fun_t;
返回結果如下。
+---------------------+----------------+-------------------------------+-----------------+ | datetime1 | datetime1_hour | timestamp1 | timestamp1_hour | +---------------------+----------------+-------------------------------+-----------------+ | 2021-11-29 00:01:00 | 0 | 2021-01-11 00:00:00.123456789 | 0 | | 2021-11-28 00:02:00 | 0 | 2021-02-11 00:00:00.123456789 | 0 | | 2021-11-27 00:03:00 | 0 | 2021-03-11 00:00:00.123456789 | 0 | | 2021-11-26 00:04:00 | 0 | 2021-04-11 00:00:00.123456789 | 0 | | 2021-11-25 00:05:00 | 0 | 2021-05-11 00:00:00.123456789 | 0 | | 2021-11-24 00:06:00 | 0 | 2021-06-11 00:00:00.123456789 | 0 | | 2021-11-23 00:07:00 | 0 | 2021-07-11 00:00:00.123456789 | 0 | | 2021-11-22 00:08:00 | 0 | 2021-08-11 00:00:00.123456789 | 0 | | 2021-11-21 00:09:00 | 0 | 2021-09-11 00:00:00.123456789 | 0 | | 2021-11-20 00:10:00 | 0 | 2021-10-11 00:00:00.123456789 | 0 | +---------------------+----------------+-------------------------------+-----------------+
ISDATE
命令格式
boolean isdate(string <date>, string <format>)
命令說明
判斷一個日期文字能否根據指定的格式串轉換為一個日期值。如果能轉換成功,返回True;否則返回False。
參數說明
date:必填。STRING類型。如果輸入為BIGINT、DOUBLE、DECIMAL或DATETIME類型,會隱式轉換為STRING類型後參與運算。
format:必填。STRING類型常量,不支援日期擴充格式。如果format中出現多餘的格式串,則只取第一個格式串對應的日期數值,其餘的會被視為分隔字元。例如
isdate("1234-yyyy", "yyyy-yyyy")
,會返回True。
傳回值說明
返回BOOLEAN類型。date或format值為NULL時,返回NULL。
樣本
待用資料樣本
--返回True。 select isdate('2021-10-11','yyyy-mm-dd'); --返回false。 set odps.sql.type.system.odps2=false; select isdate(1678952314,'yyyy-mm-dd');
表資料樣本
基於樣本資料,判斷date3是否能轉換為指定格式的日期值,命令樣本如下。
select date3, isdate(date3,'yyyy-mm-dd') as date3_isdate from mf_date_fun_t;
返回結果如下。
+------------+--------------+ | date3 | date3_isdate | +------------+--------------+ | 2021-11-20 | true | | 2021-11-21 | true | | 2021-11-22 | true | | 2021-11-23 | true | | 2021-11-24 | true | | 2021-11-25 | true | | 2021-11-26 | true | | 2021-11-27 | true | | 2021-11-28 | true | | 2021-11-29 | true | +------------+--------------+
LAST_DAY
命令格式
string last_day(date|datetime|timestamp|string <date>)
命令說明
返回該日期所在月份的最後一天日期。此函數為MaxCompute 2.0擴充函數。
參數說明
date:必填。DATE、DATETIME、TIMESTAMP或STRING類型日期值。取值為STRING類型格式時,至少要包含
yyyy-mm-dd
且不含多餘的字串。傳回值說明
返回STRING類型的日期值,格式為
yyyy-mm-dd
。返回規則如下:date非DATE、DATETIME、TIMESTAMP或STRING類型,或格式不符合要求時,返回NULL。
date值為NULL時,返回報錯。
樣本
待用資料樣本
--返回2017-03-31。 select last_day('2017-03-04'); --返回2017-07-31。 select last_day('2017-07-04 11:40:00'); --返回NULL。 select last_day('20170304');
表資料樣本
基於樣本資料,返回date1、datetime1、timestamp1和date3列日期所在月的最後一天,命令樣本如下。
--開啟2.0新類型。此命令需要與SQL語句一起提交。 set odps.sql.type.system.odps2=true; select date1, last_day(date1) as date1_lastday, datetime1, last_day(datetime1) as datetime1_lastday, timestamp1, last_day(timestamp1) as timestamp1_lastday, date3, last_day(date3) as date3_lastday from mf_date_fun_t;
返回結果如下。
+------------+---------------+---------------------+-------------------+-------------------------------+--------------------+------------+---------------+ | date1 | date1_lastday | datetime1 | datetime1_lastday | timestamp1 | timestamp1_lastday | date3 | date3_lastday | +------------+---------------+---------------------+-------------------+-------------------------------+--------------------+------------+---------------+ | 2021-11-29 | 2021-11-30 | 2021-11-29 00:01:00 | 2021-11-30 | 2021-01-11 00:00:00.123456789 | 2021-01-31 | 2021-11-20 | 2021-11-30 | | 2021-11-28 | 2021-11-30 | 2021-11-28 00:02:00 | 2021-11-30 | 2021-02-11 00:00:00.123456789 | 2021-02-28 | 2021-11-21 | 2021-11-30 | | 2021-11-27 | 2021-11-30 | 2021-11-27 00:03:00 | 2021-11-30 | 2021-03-11 00:00:00.123456789 | 2021-03-31 | 2021-11-22 | 2021-11-30 | | 2021-11-26 | 2021-11-30 | 2021-11-26 00:04:00 | 2021-11-30 | 2021-04-11 00:00:00.123456789 | 2021-04-30 | 2021-11-23 | 2021-11-30 | | 2021-11-25 | 2021-11-30 | 2021-11-25 00:05:00 | 2021-11-30 | 2021-05-11 00:00:00.123456789 | 2021-05-31 | 2021-11-24 | 2021-11-30 | | 2021-11-24 | 2021-11-30 | 2021-11-24 00:06:00 | 2021-11-30 | 2021-06-11 00:00:00.123456789 | 2021-06-30 | 2021-11-25 | 2021-11-30 | | 2021-11-23 | 2021-11-30 | 2021-11-23 00:07:00 | 2021-11-30 | 2021-07-11 00:00:00.123456789 | 2021-07-31 | 2021-11-26 | 2021-11-30 | | 2021-11-22 | 2021-11-30 | 2021-11-22 00:08:00 | 2021-11-30 | 2021-08-11 00:00:00.123456789 | 2021-08-31 | 2021-11-27 | 2021-11-30 | | 2021-11-21 | 2021-11-30 | 2021-11-21 00:09:00 | 2021-11-30 | 2021-09-11 00:00:00.123456789 | 2021-09-30 | 2021-11-28 | 2021-11-30 | | 2021-11-20 | 2021-11-30 | 2021-11-20 00:10:00 | 2021-11-30 | 2021-10-11 00:00:00.123456789 | 2021-10-31 | 2021-11-29 | 2021-11-30 | +------------+---------------+---------------------+-------------------+-------------------------------+--------------------+------------+---------------+
LASTDAY
命令格式
datetime lastday(datetime <date>)
命令說明
取date所在月的最後一天,截取到天,時分秒部分為
00:00:00
。參數說明
date:DATETIME類型日期值,格式為
yyyy-mm-dd hh:mi:ss
。如果輸入為STRING類型,且MaxCompute專案的資料類型版本是1.0,則會隱式轉換為DATETIME類型後參與運算。傳回值說明
返回DATETIME類型,格式為
yyyy-mm-dd hh:mi:ss
。返回規則如下:date非DATETIME或STRING類型,或格式不符合要求時,會返回報錯。
date值為NULL時,返回NULL。
樣本
待用資料樣本
--返回2013-06-30 00:00:00。 select lastday (datetime '2013-06-08 01:10:00'); --返回2013-06-30 00:00:00。 set odps.sql.type.system.odps2=false; select lastday ('2013-06-08 01:10:00'); --返回NULL。 select lastday (null);
表資料樣本
基於樣本資料,返回datetime1列日期所在月的最後一天,命令樣本如下。
select datetime1, lastday(datetime1) as datetime1_lastday from mf_date_fun_t;
返回結果如下。
+---------------------+---------------------+ | datetime1 | datetime1_lastday | +---------------------+---------------------+ | 2021-11-29 00:01:00 | 2021-11-30 00:00:00 | | 2021-11-28 00:02:00 | 2021-11-30 00:00:00 | | 2021-11-27 00:03:00 | 2021-11-30 00:00:00 | | 2021-11-26 00:04:00 | 2021-11-30 00:00:00 | | 2021-11-25 00:05:00 | 2021-11-30 00:00:00 | | 2021-11-24 00:06:00 | 2021-11-30 00:00:00 | | 2021-11-23 00:07:00 | 2021-11-30 00:00:00 | | 2021-11-22 00:08:00 | 2021-11-30 00:00:00 | | 2021-11-21 00:09:00 | 2021-11-30 00:00:00 | | 2021-11-20 00:10:00 | 2021-11-30 00:00:00 | +---------------------+---------------------+
MINUTE
命令格式
int minute(datetime|timestamp|string <date>)
命令說明
返回日期分鐘部分的值。此函數為MaxCompute 2.0擴充函數。
參數說明
date:必填。DATETIME、TIMESTAMP或STRING類型日期值,格式為
yyyy-mm-dd hh:mi:ss
或yyyy-mm-dd hh:mi:ss.ff3
。傳回值說明
返回INT類型。返回規則如下:
date非DATETIME、TIMESTAMP或STRING類型,或格式不符合要求時,返回NULL。
date值為NULL時,返回NULL。
樣本
待用資料樣本
--返回30。 select minute('2014-09-01 12:30:00'); --返回30。 select minute('12:30:00'); --返回NULL。 select minute('20140901120000'); --返回NULL。 select minute(null);
表資料樣本
基於樣本資料,返回datetime1和timestamp1分鐘部分的值,命令樣本如下。
--開啟2.0新類型。此命令需要與SQL語句一起提交。 set odps.sql.type.system.odps2=true; select datetime1, minute(datetime1) as datetime1_minute, timestamp1, minute(timestamp1) as timestamp1_minute from mf_date_fun_t;
返回結果如下。
+---------------------+------------------+-------------------------------+-------------------+ | datetime1 | datetime1_minute | timestamp1 | timestamp1_minute | +---------------------+------------------+-------------------------------+-------------------+ | 2021-11-29 00:01:00 | 1 | 2021-01-11 00:00:00.123456789 | 0 | | 2021-11-28 00:02:00 | 2 | 2021-02-11 00:00:00.123456789 | 0 | | 2021-11-27 00:03:00 | 3 | 2021-03-11 00:00:00.123456789 | 0 | | 2021-11-26 00:04:00 | 4 | 2021-04-11 00:00:00.123456789 | 0 | | 2021-11-25 00:05:00 | 5 | 2021-05-11 00:00:00.123456789 | 0 | | 2021-11-24 00:06:00 | 6 | 2021-06-11 00:00:00.123456789 | 0 | | 2021-11-23 00:07:00 | 7 | 2021-07-11 00:00:00.123456789 | 0 | | 2021-11-22 00:08:00 | 8 | 2021-08-11 00:00:00.123456789 | 0 | | 2021-11-21 00:09:00 | 9 | 2021-09-11 00:00:00.123456789 | 0 | | 2021-11-20 00:10:00 | 10 | 2021-10-11 00:00:00.123456789 | 0 | +---------------------+------------------+-------------------------------+-------------------+
MONTH
命令格式
int month(datetime|timestamp|date|string <date>)
命令說明
返回一個日期的月份。此函數為MaxCompute 2.0擴充函數。
參數說明
date:必填。DATETIME、TIMESTAMP、DATE或STRING類型日期值,格式為
yyyy-mm-dd
、yyyy-mm-dd hh:mi:ss
或yyyy-mm-dd hh:mi:ss.ff3
。取值為STRING類型格式時,至少要包含yyyy-mm-dd
且不含多餘的字串。傳回值說明
返回INT類型。返回規則如下:
date非DATETIME、TIMESTAMP、DATE或STRING類型,或格式不符合要求時,返回NULL。
date值為NULL時,返回NULL。
樣本
待用資料樣本
--返回9。 select month('2014-09-01'); --返回NULL。 select month('20140901'); --返回NULL。 select month(null);
表資料樣本
基於樣本資料,返回date1、datetime1、timestamp1和date3列日期所屬月份,命令樣本如下。
--開啟2.0新類型。此命令需要與SQL語句一起提交。 set odps.sql.type.system.odps2=true; select date1, month(date1) as date1_month, datetime1, month(datetime1) as datetime1_month, timestamp1, month(timestamp1) as timestamp1_month, date3, month(date3) as date3_month from mf_date_fun_t;
返回結果如下。
+------------+-------------+---------------------+-----------------+-------------------------------+------------------+------------+-------------+ | date1 | date1_month | datetime1 | datetime1_month | timestamp1 | timestamp1_month | date3 | date3_month | +------------+-------------+---------------------+-----------------+-------------------------------+------------------+------------+-------------+ | 2021-11-29 | 11 | 2021-11-29 00:01:00 | 11 | 2021-01-11 00:00:00.123456789 | 1 | 2021-11-20 | 11 | | 2021-11-28 | 11 | 2021-11-28 00:02:00 | 11 | 2021-02-11 00:00:00.123456789 | 2 | 2021-11-21 | 11 | | 2021-11-27 | 11 | 2021-11-27 00:03:00 | 11 | 2021-03-11 00:00:00.123456789 | 3 | 2021-11-22 | 11 | | 2021-11-26 | 11 | 2021-11-26 00:04:00 | 11 | 2021-04-11 00:00:00.123456789 | 4 | 2021-11-23 | 11 | | 2021-11-25 | 11 | 2021-11-25 00:05:00 | 11 | 2021-05-11 00:00:00.123456789 | 5 | 2021-11-24 | 11 | | 2021-11-24 | 11 | 2021-11-24 00:06:00 | 11 | 2021-06-11 00:00:00.123456789 | 6 | 2021-11-25 | 11 | | 2021-11-23 | 11 | 2021-11-23 00:07:00 | 11 | 2021-07-11 00:00:00.123456789 | 7 | 2021-11-26 | 11 | | 2021-11-22 | 11 | 2021-11-22 00:08:00 | 11 | 2021-08-11 00:00:00.123456789 | 8 | 2021-11-27 | 11 | | 2021-11-21 | 11 | 2021-11-21 00:09:00 | 11 | 2021-09-11 00:00:00.123456789 | 9 | 2021-11-28 | 11 | | 2021-11-20 | 11 | 2021-11-20 00:10:00 | 11 | 2021-10-11 00:00:00.123456789 | 10 | 2021-11-29 | 11 | +------------+-------------+---------------------+-----------------+-------------------------------+------------------+------------+-------------+
MONTHS_BETWEEN
命令格式
double months_between(datetime|timestamp|date|string <date1>, datetime|timestamp|date|string <date2>)
命令說明
返回日期date1和date2之間的月數。此函數為MaxCompute 2.0擴充函數。
參數說明
date1、date2:必填。DATETIME、TIMESTAMP、DATE或STRING類型,格式為
yyyy-mm-dd
、yyyy-mm-dd hh:mi:ss
或yyyy-mm-dd hh:mi:ss.ff3
。取值為STRING類型格式時,至少要包含yyyy-mm-dd
且不含多餘的字串。傳回值說明
返回DOUBLE類型。返回規則如下:
當date1晚於date2時,傳回值為正。當date2晚於date1時,傳回值為負。
當date1和date2分別對應兩個月的最後一天,返回整數月;否則計算方式為date1減去date2的天數除以31天。
date1或date2值為NULL時,返回NULL。
樣本
待用資料樣本
--返回3.9495967741935485。 select months_between('1997-02-28 10:30:00', '1996-10-30'); --返回-3.9495967741935485。 select months_between('1996-10-30','1997-02-28 10:30:00' ); --返回-3.0。 select months_between('1996-09-30','1996-12-31'); --返回NULL。 select months_between('1996-09-30',null);
表資料樣本
基於樣本資料,計算timestamp1和timestamp2列之間的月數,命令樣本如下。
--開啟2.0新類型。此命令需要與SQL語句一起提交。 set odps.sql.type.system.odps2=true; select timestamp1, timestamp2, months_between(timestamp1, timestamp2) from mf_date_fun_t;
返回結果如下。
+-------------------------------+-------------------------------+------------+ | timestamp1 | timestamp2 | _c2 | +-------------------------------+-------------------------------+------------+ | 2021-01-11 00:00:00.123456789 | 2021-10-11 00:00:00.123456789 | -9.0 | | 2021-02-11 00:00:00.123456789 | 2021-10-11 00:00:00.123456789 | -8.0 | | 2021-03-11 00:00:00.123456789 | 2021-10-11 00:00:00.123456789 | -7.0 | | 2021-04-11 00:00:00.123456789 | 2021-10-11 00:00:00.123456789 | -6.0 | | 2021-05-11 00:00:00.123456789 | 2021-10-11 00:00:00.123456789 | -5.0 | | 2021-06-11 00:00:00.123456789 | 2021-10-11 00:00:00.123456789 | -4.0 | | 2021-07-11 00:00:00.123456789 | 2021-10-11 00:00:00.123456789 | -3.0 | | 2021-08-11 00:00:00.123456789 | 2021-10-11 00:00:00.123456789 | -2.0 | | 2021-09-11 00:00:00.123456789 | 2021-10-11 00:00:00.123456789 | -1.0 | | 2021-10-11 00:00:00.123456789 | 2021-10-11 00:00:00.123456789 | 0.0 | +------------+------------+------------+
NEXT_DAY
命令格式
string next_day(timestamp|date|datetime|string <startdate>, string <week>)
命令說明
返回大於指定日期startdate並且與week相匹配的第一個日期,即下周幾的具體日期。此函數為MaxCompute 2.0擴充函數。
參數說明
startdate:必填。TIMESTAMP、DATE、DATETIME或STRING類型日期值,格式為
yyyy-mm-dd
、yyyy-mm-dd hh:mi:ss
或yyyy-mm-dd hh:mi:ss.ff3
。取值為STRING類型格式時,至少要包含yyyy-mm-dd
且不含多餘的字串。week:必填。STRING類型,一個星期前2個或3個字母,或者一個星期的全名。例如MO、TUE或FRIDAY。
傳回值說明
返回STRING類型的日期值,格式為
yyyy-mm-dd
。返回規則如下:date非TIMESTAMP、DATE、DATETIME或STRING類型,或格式不符合要求時,返回NULL。
date值為NULL時,返回報錯。
week值為NULL時,返回NULL。
樣本
待用資料樣本
--返回2017-08-08。 select next_day('2017-08-01','TU'); --返回2017-08-08。 select next_day('2017-08-01 23:34:00','TU'); --返回NULL。 select next_day('20170801','TU'); --返回NULL。 select next_day('2017-08-01 23:34:00',null);
表資料樣本
基於樣本資料,返回date1、datetime1、timestamp1和date3列對應下周的具體日期,命令樣本如下。
--開啟2.0新類型。此命令需要與SQL語句一起提交。 set odps.sql.type.system.odps2=true; select date1, next_day(date1,'MON') as date1_next_day, datetime1, next_day(datetime1,'TUE') as datetime1_next_day, timestamp1, next_day(timestamp1,'WED') as timestamp1_next_day, date3, next_day(date3,'THU') as date3_next_day from mf_date_fun_t;
返回結果如下。
+------------+----------------+---------------------+--------------------+-------------------------------+---------------------+------------+----------------+ | date1 | date1_next_day | datetime1 | datetime1_next_day | timestamp1 | timestamp1_next_day | date3 | date3_next_day | +------------+----------------+---------------------+--------------------+-------------------------------+---------------------+------------+----------------+ | 2021-11-29 | 2021-12-06 | 2021-11-29 00:01:00 | 2021-11-30 | 2021-01-11 00:00:00.123456789 | 2021-01-13 | 2021-11-20 | 2021-11-25 | | 2021-11-28 | 2021-11-29 | 2021-11-28 00:02:00 | 2021-11-30 | 2021-02-11 00:00:00.123456789 | 2021-02-17 | 2021-11-21 | 2021-11-25 | | 2021-11-27 | 2021-11-29 | 2021-11-27 00:03:00 | 2021-11-30 | 2021-03-11 00:00:00.123456789 | 2021-03-17 | 2021-11-22 | 2021-11-25 | | 2021-11-26 | 2021-11-29 | 2021-11-26 00:04:00 | 2021-11-30 | 2021-04-11 00:00:00.123456789 | 2021-04-14 | 2021-11-23 | 2021-11-25 | | 2021-11-25 | 2021-11-29 | 2021-11-25 00:05:00 | 2021-11-30 | 2021-05-11 00:00:00.123456789 | 2021-05-12 | 2021-11-24 | 2021-11-25 | | 2021-11-24 | 2021-11-29 | 2021-11-24 00:06:00 | 2021-11-30 | 2021-06-11 00:00:00.123456789 | 2021-06-16 | 2021-11-25 | 2021-12-02 | | 2021-11-23 | 2021-11-29 | 2021-11-23 00:07:00 | 2021-11-30 | 2021-07-11 00:00:00.123456789 | 2021-07-14 | 2021-11-26 | 2021-12-02 | | 2021-11-22 | 2021-11-29 | 2021-11-22 00:08:00 | 2021-11-23 | 2021-08-11 00:00:00.123456789 | 2021-08-18 | 2021-11-27 | 2021-12-02 | | 2021-11-21 | 2021-11-22 | 2021-11-21 00:09:00 | 2021-11-23 | 2021-09-11 00:00:00.123456789 | 2021-09-15 | 2021-11-28 | 2021-12-02 | | 2021-11-20 | 2021-11-22 | 2021-11-20 00:10:00 | 2021-11-23 | 2021-10-11 00:00:00.123456789 | 2021-10-13 | 2021-11-29 | 2021-12-02 | +------------+----------------+---------------------+--------------------+-------------------------------+---------------------+------------+----------------+
NOW
命令格式
datetime NOW()
命令說明
返回當前系統日期與時間。
傳回值說明
返回DATETIME類型,格式為
yyyy-mm-dd hh:mi:ss.SSS
。樣本
不指定格式,返回毫秒位可能為1位、2位或者3位:
select now();
返回結果如下:
+------+ | _c0 | +------+ | 2023-06-13 10:53:24.967 | +------+
指定時間格式:
select date_format(now(),'yyyy-MM-dd hh:mm:ss.SSS') ;
返回結果如下:
+-----+ | _c0 | +-----+ | 2023-06-13 10:53:53.899 | +-----+
QUARTER
命令格式
int quarter (datetime|timestamp|date|string <date>)
命令說明
返回一個日期的季度,範圍是1~4。此函數為MaxCompute 2.0擴充函數。
參數說明
date:必填。DATETIME、TIMESTAMP、DATE或STRING類型日期值,格式為
yyyy-mm-dd
、yyyy-mm-dd hh:mi:ss
或yyyy-mm-dd hh:mi:ss.ff3
。取值為STRING類型格式時,至少要包含yyyy-mm-dd
且不含多餘的字串。傳回值說明
返回INT類型。返回規則如下:
date非DATETIME、TIMESTAMP、DATE或STRING類型,或格式不符合要求時,返回NULL。
date值為NULL時,返回NULL。
樣本
待用資料樣本
--返回4。 select quarter('1970-11-12 10:00:00'); --返回4。 select quarter('1970-11-12'); --返回NULL。 select quarter(null);
表資料樣本
基於樣本資料,返回date1、datetime1、timestamp1和date3列日期所屬季度,命令樣本如下。
--開啟2.0新類型。此命令需要與SQL語句一起提交。 set odps.sql.type.system.odps2=true; select date1, quarter(date1) as date1_quarter, datetime1, quarter(datetime1) as datetime1_quarter, timestamp1, quarter(timestamp1) as timestamp1_quarter, date3, quarter(date3) as date3_quarter from mf_date_fun_t;
返回結果如下。
+------------+---------------+---------------------+-------------------+-------------------------------+--------------------+------------+---------------+ | date1 | date1_quarter | datetime1 | datetime1_quarter | timestamp1 | timestamp1_quarter | date3 | date3_quarter | +------------+---------------+---------------------+-------------------+-------------------------------+--------------------+------------+---------------+ | 2021-11-29 | 4 | 2021-11-29 00:01:00 | 4 | 2021-01-11 00:00:00.123456789 | 1 | 2021-11-20 | 4 | | 2021-11-28 | 4 | 2021-11-28 00:02:00 | 4 | 2021-02-11 00:00:00.123456789 | 1 | 2021-11-21 | 4 | | 2021-11-27 | 4 | 2021-11-27 00:03:00 | 4 | 2021-03-11 00:00:00.123456789 | 1 | 2021-11-22 | 4 | | 2021-11-26 | 4 | 2021-11-26 00:04:00 | 4 | 2021-04-11 00:00:00.123456789 | 2 | 2021-11-23 | 4 | | 2021-11-25 | 4 | 2021-11-25 00:05:00 | 4 | 2021-05-11 00:00:00.123456789 | 2 | 2021-11-24 | 4 | | 2021-11-24 | 4 | 2021-11-24 00:06:00 | 4 | 2021-06-11 00:00:00.123456789 | 2 | 2021-11-25 | 4 | | 2021-11-23 | 4 | 2021-11-23 00:07:00 | 4 | 2021-07-11 00:00:00.123456789 | 3 | 2021-11-26 | 4 | | 2021-11-22 | 4 | 2021-11-22 00:08:00 | 4 | 2021-08-11 00:00:00.123456789 | 3 | 2021-11-27 | 4 | | 2021-11-21 | 4 | 2021-11-21 00:09:00 | 4 | 2021-09-11 00:00:00.123456789 | 3 | 2021-11-28 | 4 | | 2021-11-20 | 4 | 2021-11-20 00:10:00 | 4 | 2021-10-11 00:00:00.123456789 | 4 | 2021-11-29 | 4 | +------------+---------------+---------------------+-------------------+-------------------------------+--------------------+------------+---------------+
SECOND
命令格式
int second(datetime|timestamp|string <date>)
命令說明
返回日期秒數部分的值。此函數為MaxCompute 2.0擴充函數。
參數說明
date:必填。DATETIME、TIMESTAMP或STRING類型日期值,格式為
yyyy-mm-dd hh:mi:ss
或yyyy-mm-dd hh:mi:ss.ff3
。傳回值說明
返回INT類型。返回規則如下:
date非DATETIME、TIMESTAMP或STRING類型,或格式不符合要求時,返回NULL。
date值為NULL時,返回NULL。
樣本
待用資料樣本
--返回45。 select second('2014-09-01 12:30:45'); --返回45。 select second('12:30:45'); --返回NULL。 select second('20140901123045'); --返回NULL。 select second(null);
表資料樣本
基於樣本資料,返回datetime1和timestamp1列秒數部分的值,命令樣本如下。
--開啟2.0新類型。此命令需要與SQL語句一起提交。 set odps.sql.type.system.odps2=true; elect datetime1, second(datetime1) as datetime1_second, timestamp1, second(timestamp1) as timestamp1_second from mf_date_fun_t;
返回結果如下。
+---------------------+------------------+-------------------------------+-------------------+ | datetime1 | datetime1_second | timestamp1 | timestamp1_second | +---------------------+------------------+-------------------------------+-------------------+ | 2021-11-29 00:01:00 | 0 | 2021-01-11 00:00:00.123456789 | 0 | | 2021-11-28 00:02:00 | 0 | 2021-02-11 00:00:00.123456789 | 0 | | 2021-11-27 00:03:00 | 0 | 2021-03-11 00:00:00.123456789 | 0 | | 2021-11-26 00:04:00 | 0 | 2021-04-11 00:00:00.123456789 | 0 | | 2021-11-25 00:05:00 | 0 | 2021-05-11 00:00:00.123456789 | 0 | | 2021-11-24 00:06:00 | 0 | 2021-06-11 00:00:00.123456789 | 0 | | 2021-11-23 00:07:00 | 0 | 2021-07-11 00:00:00.123456789 | 0 | | 2021-11-22 00:08:00 | 0 | 2021-08-11 00:00:00.123456789 | 0 | | 2021-11-21 00:09:00 | 0 | 2021-09-11 00:00:00.123456789 | 0 | | 2021-11-20 00:10:00 | 0 | 2021-10-11 00:00:00.123456789 | 0 | +---------------------+------------------+-------------------------------+-------------------+
TO_CHAR
命令格式
string to_char(datetime <date>, string <format>)
命令說明
將日期類型date按照format指定的格式轉成字串。
參數說明
date:必填。DATETIME類型日期值,格式為
yyyy-mm-dd hh:mi:ss
。如果輸入為STRING類型,且MaxCompute專案的資料類型版本是1.0,會隱式轉換為DATETIME類型後參與運算。
format:必填。STRING類型常量。format中的日期格式部分會被替換成相應的資料,其他字元直接輸出。
傳回值說明
返回STRING類型。返回規則如下:
date非DATETIME或STRING類型時,返回報錯。
date值為NULL時,返回報錯。
format值為NULL時,返回NULL。
樣本
待用資料樣本
樣本1
--需要注意在Windows環境的MaxCompute用戶端運行時返回結果中的中文字元顯示存在問題 SELECT TO_CHAR(DATETIME '2010-12-03 00:00:00','阿里金融yyyy-mm*dd');
返回結果如下。
+------------+ | _c0 | +------------+ | 阿里金融2010-12*03 | +------------+
樣本2
SELECT TO_CHAR(DATETIME '2008-07-18 00:00:00','yyyymmdd');
返回結果如下。
+------------+ | _c0 | +------------+ | 20080718 | +------------+
樣本3
SET odps.sql.type.system.odps2=false; SELECT TO_CHAR('2008-07-18 00:00:00', 'yyyymmdd');
返回結果如下。
+------------+ | _c0 | +------------+ | 20080718 | +------------+
樣本4
--'阿里巴巴2010-12*3'無法轉換為符合要求的格式,會引發異常,應該為'阿里巴巴2010-12*03'。 SELECT TO_CHAR(datetime'阿里巴巴2010-12*3', '阿里巴巴yyyy-mm*dd');
樣本5
--'20102401'不是標準日期值,引發異常,應該為'2010-01-24 00:00:00'。 SELECT TO_CHAR(datetime'20102401', 'yyyy');
樣本6
SELECT TO_CHAR(datetime'2010-12-03 00:00:00', null);
返回結果如下。
+------------+ | _c0 | +------------+ | NULL | +------------+
表資料樣本
基於樣本資料,將datetime1列日期轉換為滿足指定格式的字串,命令樣本如下。
SELECT datetime1 ,TO_CHAR(datetime1,'yyyy-mm-dd') AS datetime1_to_char FROM mf_date_fun_t;
返回結果如下。
+---------------------+-------------------+ | datetime1 | datetime1_to_char | +---------------------+-------------------+ | 2021-11-29 00:01:00 | 2021-11-29 | | 2021-11-28 00:02:00 | 2021-11-28 | | 2021-11-27 00:03:00 | 2021-11-27 | | 2021-11-26 00:04:00 | 2021-11-26 | | 2021-11-25 00:05:00 | 2021-11-25 | | 2021-11-24 00:06:00 | 2021-11-24 | | 2021-11-23 00:07:00 | 2021-11-23 | | 2021-11-22 00:08:00 | 2021-11-22 | | 2021-11-21 00:09:00 | 2021-11-21 | | 2021-11-20 00:10:00 | 2021-11-20 | +---------------------+-------------------+
TO_DATE
命令格式
datetime|date to_date(string <date>[, string <format>])
命令說明
將date轉換成符合format格式的日期值。
參數說明
date:必填。STRING類型,要轉換的字串格式的日期值。如果輸入為BIGINT、DOUBLE、DECIMAL或DATETIME類型,則會隱式轉換為STRING類型後參與運算。該函數還支援ISO8601時間格式的字串。
format:可選。STRING類型常量,日期格式。format不支援日期擴充格式,其他字元在解析時當作無用字元忽略。
format:參數至少包含
yyyy
,否則會返回NULL。如果format中出現多餘的格式串,則只取第一個格式串對應的日期數值,其餘的會被視為分隔字元。例如to_date("1234-2234", "yyyy-yyyy")
會返回1234-01-01 00:00:00
。format格式:
yyyy
為4位元的年,mm
為2位元的月,dd
為2位元的日,hh
為24小時制的時,mi
為2位元的分鐘,ss
為2位元秒,ff3
為3位精度毫秒。
傳回值說明
返回DATE或DATETIME類型。
當函數入參無format參數,且待轉換的字串格式為yyyy-mm-dd或
yyyy-mm-dd hh:mi:ss
時,返回DATE類型,格式為yyyy-mm-dd
;否則,返回NULL。當函數入參有format參數時,返回DATETIME類型,格式為
yyyy-mm-dd hh:mi:ss
。date或format值為NULL時,返回NULL。
樣本
待用資料樣本
--返回2010-12-03 00:00:00。 select to_date('阿里巴巴2010-12*03', '阿里巴巴yyyy-mm*dd'); --返回2008-07-18 00:00:00。 select to_date('20080718', 'yyyymmdd'); --返回2008-07-18 20:30:00。 select to_date('200807182030','yyyymmddhhmi'); --'2008718'無法轉為標準日期值,引發異常,應該為'20080718'。 select to_date('2008718', 'yyyymmdd'); --'阿里巴巴2010-12*3'無法轉為標準日期值,引發異常,應該為'阿里巴巴2010-12*03'。 select to_date('阿里巴巴2010-12*3', '阿里巴巴yyyy-mm*dd'); --'2010-24-01'無法轉為標準日期值,引發異常,應該為'2010-01-24'。 select to_date('2010-24-01', 'yyyy-mm-dd'); --返回2018-10-30 15:13:12。 select to_date('20181030 15-13-12.345','yyyymmdd hh-mi-ss.ff3'); --返回NULL。 select to_date(null,'yyyymmdd hh-mi-ss.ff3'); --返回NULL。 select to_date('20181030 15-13-12.345',null); --ISO8601時間格式,返回2021-09-24 13:39:34。 select to_date('2021-09-24T13:39:34.119Z', 'yyyy-MM-ddThh:mi:ss.ff3Z'); --返回2021-09-24,資料類型為Date。 select to_date('2021-09-24'); --返回2021-09-24,資料類型為Date。 select to_date('2021-09-24 13:39:34'); --返回NULL。 select to_date('20210924');
表資料樣本
基於樣本資料,將date3列日期轉換為滿足指定格式的日期值,命令樣本如下。
select date3, to_date(date3, 'yyyy-mm-dd') as date3_to_date from mf_date_fun_t;
返回結果如下。
+------------+---------------------+ | date3 | date3_to_date | +------------+---------------------+ | 2021-11-20 | 2021-11-20 00:00:00 | | 2021-11-21 | 2021-11-21 00:00:00 | | 2021-11-22 | 2021-11-22 00:00:00 | | 2021-11-23 | 2021-11-23 00:00:00 | | 2021-11-24 | 2021-11-24 00:00:00 | | 2021-11-25 | 2021-11-25 00:00:00 | | 2021-11-26 | 2021-11-26 00:00:00 | | 2021-11-27 | 2021-11-27 00:00:00 | | 2021-11-28 | 2021-11-28 00:00:00 | | 2021-11-29 | 2021-11-29 00:00:00 | +------------+---------------------+
TO_MILLIS
命令格式
bigint to_millis(datetime|timestamp <date>);
命令說明
將給定日期date轉換為以毫秒為單位的UNIX時間戳記。此函數為MaxCompute 2.0擴充函數。
參數說明
date:必填。DATETIME或TIMESTAMP類型日期值,格式為
yyyy-mm-dd hh:mi:ss
或yyyy-mm-dd hh:mi:ss.ff3
。傳回值說明
返回BIGINT類型。返回規則如下:
date非DATETIME或TIMESTAMP類型時,返回報錯。
date值為NULL時,返回報錯。
樣本
待用資料樣本
--返回1617174900000。 select to_millis(datetime '2021-03-31 15:15:00'); --返回1617174900000。 set odps.sql.type.system.odps2=true; select to_millis(timestamp '2021-03-31 15:15:00');
表資料樣本
基於樣本資料,將datetime1和timestamp1轉換為以毫秒為單位的UNIX時間戳記,命令樣本如下。
--開啟2.0新類型。此命令需要與SQL語句一起提交。 set odps.sql.type.system.odps2=true; select datetime1, to_millis(datetime1) as datetime1_to_millis, timestamp1, to_millis(timestamp1) as timestamp1_to_millis from mf_date_fun_t;
返回結果如下。
+---------------------+---------------------+-------------------------------+----------------------+ | datetime1 | datetime1_to_millis | timestamp1 | timestamp1_to_millis | +---------------------+---------------------+-------------------------------+----------------------+ | 2021-11-29 00:01:00 | 1638115260000 | 2021-01-11 00:00:00.123456789 | 1610294400123 | | 2021-11-28 00:02:00 | 1638028920000 | 2021-02-11 00:00:00.123456789 | 1612972800123 | | 2021-11-27 00:03:00 | 1637942580000 | 2021-03-11 00:00:00.123456789 | 1615392000123 | | 2021-11-26 00:04:00 | 1637856240000 | 2021-04-11 00:00:00.123456789 | 1618070400123 | | 2021-11-25 00:05:00 | 1637769900000 | 2021-05-11 00:00:00.123456789 | 1620662400123 | | 2021-11-24 00:06:00 | 1637683560000 | 2021-06-11 00:00:00.123456789 | 1623340800123 | | 2021-11-23 00:07:00 | 1637597220000 | 2021-07-11 00:00:00.123456789 | 1625932800123 | | 2021-11-22 00:08:00 | 1637510880000 | 2021-08-11 00:00:00.123456789 | 1628611200123 | | 2021-11-21 00:09:00 | 1637424540000 | 2021-09-11 00:00:00.123456789 | 1631289600123 | | 2021-11-20 00:10:00 | 1637338200000 | 2021-10-11 00:00:00.123456789 | 1633881600123 | +---------------------+---------------------+-------------------------------+----------------------+
UNIX_TIMESTAMP
命令格式
bigint unix_timestamp(datetime|date|timestamp|string <date>)
命令說明
將日期date轉化為整型的UNIX格式的日期時間值。
參數說明
date:必填。DATETIME、DATE、TIMESTAMP或STRING類型日期值,格式為
yyyy-mm-dd hh:mi:ss
、yyyy-mm-dd
或yyyy-mm-dd hh:mi:ss.ff3
。如果輸入為STRING類型,且MaxCompute專案的資料類型版本是1.0資料類型版本,則會隱式轉換為DATETIME類型後參與運算。當使用MaxCompute2.0資料類型版本(2.0資料類型版本)時,隱式轉換會失敗,此時需要通過cast
函數轉換或關閉新資料類型,例如unix_timestamp(cast(... as datetime))
。說明當入參為常量資料(非表資料)時,格式應寫為:
DATETIME'yyyy-mm-dd hh:mi:ss'
、DATE'yyyy-mm-dd'
或TIMESTAMP'yyyy-mm-dd hh:mi:ss.ff3'
,無資料類型關鍵字時(即寫為'yyyy-mm-dd hh:mi:ss'
),會識別為STRING類型。傳回值說明
返回BIGINT類型,表示UNIX格式日期值。返回規則如下:
date非DATETIME、DATE、TIMESTAMP或STRING類型,或格式不符合要求時,返回報錯或NULL。
date值為NULL時,返回NULL。
樣本
待用資料樣本
--返回1699585860。 SELECT unix_timestamp(DATETIME'2023-11-10 11:11:00'); --返回1699545600 set odps.sql.type.system.odps2=true; SELECT unix_timestamp(DATE'2023-11-10'); --返回1699585860 set odps.sql.type.system.odps2=true; SELECT unix_timestamp(TIMESTAMP'2023-11-10 11:11:00.123456789'); --返回1237518660。 set odps.sql.type.system.odps2=false; select unix_timestamp('2009-03-20 11:11:00'); --返回NULL。 select unix_timestamp(null);
表資料樣本
基於樣本資料,將date1、datetime1和timestamp1列日期轉換為整型的UNIX格式的日期值,命令樣本如下。
--開啟2.0新類型。此命令需要與SQL語句一起提交。 set odps.sql.type.system.odps2=true; select date1, unix_timestamp(date1) as date1_unix_timestamp, datetime1, unix_timestamp(datetime1) as datetime1_unix_timestamp, timestamp1, unix_timestamp(timestamp1) as timestamp1_unix_timestamp from mf_date_fun_t;
返回結果如下。
+------------+----------------------+---------------------+--------------------------+------------------------------+---------------------------+ | date1 | date1_unix_timestamp | datetime1 | datetime1_unix_timestamp | timestamp1 | timestamp1_unix_timestamp | +------------+----------------------+---------------------+--------------------------+------------------------------+---------------------------+ | 2021-11-29 | 1638115200 | 2021-11-29 00:01:00 | 1638115260 | 2021-01-11 00:00:00.123456789 | 1610294400 | | 2021-11-28 | 1638028800 | 2021-11-28 00:02:00 | 1638028920 | 2021-02-11 00:00:00.123456789 | 1612972800 | | 2021-11-27 | 1637942400 | 2021-11-27 00:03:00 | 1637942580 | 2021-03-11 00:00:00.123456789 | 1615392000 | | 2021-11-26 | 1637856000 | 2021-11-26 00:04:00 | 1637856240 | 2021-04-11 00:00:00.123456789 | 1618070400 | | 2021-11-25 | 1637769600 | 2021-11-25 00:05:00 | 1637769900 | 2021-05-11 00:00:00.123456789 | 1620662400 | | 2021-11-24 | 1637683200 | 2021-11-24 00:06:00 | 1637683560 | 2021-06-11 00:00:00.123456789 | 1623340800 | | 2021-11-23 | 1637596800 | 2021-11-23 00:07:00 | 1637597220 | 2021-07-11 00:00:00.123456789 | 1625932800 | | 2021-11-22 | 1637510400 | 2021-11-22 00:08:00 | 1637510880 | 2021-08-11 00:00:00.123456789 | 1628611200 | | 2021-11-21 | 1637424000 | 2021-11-21 00:09:00 | 1637424540 | 2021-09-11 00:00:00.123456789 | 1631289600 | | 2021-11-20 | 1637337600 | 2021-11-20 00:10:00 | 1637338200 | 2021-10-11 00:00:00.123456789 | 1633881600 | +------------+----------------------+---------------------+--------------------------+------------------------------+---------------------------+
WEEKDAY
命令格式
bigint weekday (datetime <date>)
命令說明
返回date日期是當前周的第幾天。
參數說明
date:必填。DATETIME類型日期值。格式為
yyyy-mm-dd hh:mi:ss
。如果輸入為STRING類型,且MaxCompute專案的資料類型版本是1.0,則會隱式轉換為DATETIME類型後參與運算。傳回值說明
返回BIGINT類型。返回規則如下:
周一作為一周的第一天,傳回值為0。其他日期依次遞增,周日返回6。
date非DATETIME或STRING類型,或格式不符合要求時,返回報錯。
date值為NULL時,返回NULL。
樣本
待用資料樣本
--返回4。 select weekday (datetime '2009-03-20 11:11:00'); --返回4。 set odps.sql.type.system.odps2=false; select weekday ('2009-03-20 11:11:00'); --返回NULL。 select weekday (null);
表資料樣本
基於樣本資料,計算datetime1列日期為所在周的第幾天,命令樣本如下。
select datetime1, weekday(datetime1) as datetime1_weekday from mf_date_fun_t;
返回結果如下。
+---------------------+-------------------+ | datetime1 | datetime1_weekday | +---------------------+-------------------+ | 2021-11-29 00:01:00 | 0 | | 2021-11-28 00:02:00 | 6 | | 2021-11-27 00:03:00 | 5 | | 2021-11-26 00:04:00 | 4 | | 2021-11-25 00:05:00 | 3 | | 2021-11-24 00:06:00 | 2 | | 2021-11-23 00:07:00 | 1 | | 2021-11-22 00:08:00 | 0 | | 2021-11-21 00:09:00 | 6 | | 2021-11-20 00:10:00 | 5 | +---------------------+-------------------+
WEEKOFYEAR
命令格式
bigint weekofyear (datetime <date>)
命令說明
返回日期date位於那一年的第幾周。周一作為一周的第一天。
說明這一周算上一年還是下一年,取決於這一周的大多數日期(4天以上)在哪一年。算在前一年,就是前一年的最後一周;算在後一年就是後一年的第一周。
參數說明
date:必填。DATETIME類型日期值。格式為
yyyy-mm-dd hh:mi:ss
。如果輸入為STRING類型,且MaxCompute專案的資料類型版本是1.0,則會隱式轉換為DATETIME類型後參與運算。傳回值說明
返回BIGINT類型。返回規則如下:
date非DATETIME或STRING類型,或格式不符合要求時,返回NULL。
date值為NULL時,返回NULL。
樣本
待用資料樣本
--返回1。雖然20141229屬於2014年,但是這一周的大多數日期是在2015年,因此返回結果為1,表示是2015年的第一周。 select weekofyear(to_date("20141229", "yyyymmdd")); --返回1。 select weekofyear(to_date("20141231", "yyyymmdd")); --返回53。 select weekofyear(to_date("20151229", "yyyymmdd")); --返回48。 set odps.sql.type.system.odps2=false; select weekofyear('2021-11-29 00:01:00'); --返回NULL。 select weekofyear('20141231'); --返回NULL。 select weekofyear(null);
表資料樣本
基於樣本資料,計算datetime1列日期為所在年的第幾周,命令樣本如下。
select datetime1, weekofyear(datetime1) as datetime1_weekofyear from mf_date_fun_t;
返回結果如下。
+---------------------+----------------------+ | datetime1 | datetime1_weekofyear | +---------------------+----------------------+ | 2021-11-29 00:01:00 | 48 | | 2021-11-28 00:02:00 | 47 | | 2021-11-27 00:03:00 | 47 | | 2021-11-26 00:04:00 | 47 | | 2021-11-25 00:05:00 | 47 | | 2021-11-24 00:06:00 | 47 | | 2021-11-23 00:07:00 | 47 | | 2021-11-22 00:08:00 | 47 | | 2021-11-21 00:09:00 | 46 | | 2021-11-20 00:10:00 | 46 | +---------------------+----------------------+
YEAR
命令格式
int year(datetime|timestamp|date|string <date>)
命令說明
返回日期date的年。此函數為MaxCompute 2.0擴充函數。
參數說明
date:必填。DATETIME、TIMESTAMP、DATE或STRING類型日期值,格式為
yyyy-mm-dd
、yyyy-mm-dd hh:mi:ss
或yyyy-mm-dd hh:mi:ss.ff3
。取值為STRING類型格式時,至少要包含yyyy-mm-dd
且不含多餘的字串。傳回值
返回INT類型。返回規則如下:
date非DATETIME、TIMESTAMP、DATE或STRING類型,或格式不符合要求時,返回NULL。
date值為NULL時,返回NULL。
樣本
待用資料樣本
--返回1970。 select year('1970-01-01 12:30:00'); --返回1970。 select year('1970-01-01'); --返回70。 select year('70-01-01'); --返回NULL。 select year('1970/03/09'); --返回NULL。 select year(null);
表資料樣本
基於樣本資料,返回date1、datetime1、timestamp1和date3列日期所屬年份,命令樣本如下。
--開啟2.0新類型。此命令需要與SQL語句一起提交。 set odps.sql.type.system.odps2=true; select date1, year(date1) as date1_year, datetime1, year(datetime1) as datetime1_year, timestamp1, year(timestamp1) as timestamp1_year, date3, year(date3) as date3_year from mf_date_fun_t;
返回結果如下。
+------------+------------+---------------------+----------------+-------------------------------+-----------------+------------+------------+ | date1 | date1_year | datetime1 | datetime1_year | timestamp1 | timestamp1_year | date3 | date3_year | +------------+------------+---------------------+----------------+-------------------------------+-----------------+------------+------------+ | 2021-11-29 | 2021 | 2021-11-29 00:01:00 | 2021 | 2021-01-11 00:00:00.123456789 | 2021 | 2021-11-20 | 2021 | | 2021-11-28 | 2021 | 2021-11-28 00:02:00 | 2021 | 2021-02-11 00:00:00.123456789 | 2021 | 2021-11-21 | 2021 | | 2021-11-27 | 2021 | 2021-11-27 00:03:00 | 2021 | 2021-03-11 00:00:00.123456789 | 2021 | 2021-11-22 | 2021 | | 2021-11-26 | 2021 | 2021-11-26 00:04:00 | 2021 | 2021-04-11 00:00:00.123456789 | 2021 | 2021-11-23 | 2021 | | 2021-11-25 | 2021 | 2021-11-25 00:05:00 | 2021 | 2021-05-11 00:00:00.123456789 | 2021 | 2021-11-24 | 2021 | | 2021-11-24 | 2021 | 2021-11-24 00:06:00 | 2021 | 2021-06-11 00:00:00.123456789 | 2021 | 2021-11-25 | 2021 | | 2021-11-23 | 2021 | 2021-11-23 00:07:00 | 2021 | 2021-07-11 00:00:00.123456789 | 2021 | 2021-11-26 | 2021 | | 2021-11-22 | 2021 | 2021-11-22 00:08:00 | 2021 | 2021-08-11 00:00:00.123456789 | 2021 | 2021-11-27 | 2021 | | 2021-11-21 | 2021 | 2021-11-21 00:09:00 | 2021 | 2021-09-11 00:00:00.123456789 | 2021 | 2021-11-28 | 2021 | | 2021-11-20 | 2021 | 2021-11-20 00:10:00 | 2021 | 2021-10-11 00:00:00.123456789 | 2021 | 2021-11-29 | 2021 | +------------+------------+---------------------+----------------+-------------------------------+-----------------+------------+------------+