Apache Pig - ToDate() 函数



此函数用于根据给定的参数生成一个 **DateTime** 对象。

语法

**ToDate()** 函数的语法可以是以下任何一种:

grunt> ToDate(milliseconds)
  
grunt> ToDate(iosstring) 
  
grunt> ToDate(userstring, format)
  
grunt> ToDate(userstring, format, timezone)

示例

假设在 **HDFS** 目录 ** /pig_data/ ** 中有一个名为 **date.txt** 的文件。此文件包含某人的出生日期详细信息,包括 ID、日期和时间。

date.txt

001,1989/09/26 09:00:00
002,1980/06/20 10:22:00
003,1990/12/19 03:11:44 

并且,我们已使用名为 **date_data** 的关系将此文件加载到 Pig 中,如下所示。

grunt> date_data = LOAD 'hdfs://127.0.0.1:9000/pig_data/date.txt' USING PigStorage(',')
   as (id:int,date:chararray);

以下是 **ToDate()** 函数的示例。这里我们将每个员工的出生日期转换为对应的 DateTime 对象。

grunt> todate_data = foreach date_data generate ToDate(date,'yyyy/MM/dd HH:mm:ss')
   as (date_time:DateTime >);

语句的结果(每个员工的 **DateTime** 对象)将存储在名为 **todate_data** 的关系中。使用 Dump 操作符验证此关系的内容,如下所示。

grunt> Dump todate_data;
  
(1989-09-26T09:00:00.000+05:30)
(1980-06-20T10:22:00.000+05:30)
(1990-12-19T03:11:44.000+05:30)
apache_pig_date_time_functions.htm
广告