设为首页 加入收藏

TOP

kettle日期参数使用
2015-07-24 09:35:03 来源: 作者: 【 】 浏览:0
Tags:kettle 日期 参数 使用

在使用日期类型参数进行比较大小的时候,务必保证传递的日期类型参数和比较的类型保持一致。

在ETL过程中使用日期类型的参数很是常见,例如SQL如下:

  
   
SELECT b.display_name,
a.company_id,
date_format(max(first_send_notice_date), ‘%Y-%m’) accMonth,
count(*) totalReport,
sum(CASE WHEN a.takeoff_time > ‘1980’ THEN 1 ELSE 0 END) removed ,
sum(CASE WHEN a.takeoff_time > ‘1980’
AND a.takeoff_time < a.first_send_notice_date + interval 1 DAY THEN 1 ELSE 0 END) 1DAY ,
sum(CASE WHEN a.takeoff_time >=a.first_send_notice_date + interval 1 DAY
AND a.takeoff_time < a.first_send_notice_date + interval 3 DAY THEN 1 ELSE 0 END) 2_3day ,
sum(CASE WHEN a.takeoff_time >=a.first_send_notice_date + interval 3 DAY
AND a.takeoff_time < a.first_send_notice_date + interval 5 DAY THEN 1 ELSE 0 END) 4_5day ,
sum(CASE WHEN a.takeoff_time >=a.first_send_notice_date + interval 5 DAY
AND a.takeoff_time < a.first_send_notice_date + interval 7 DAY THEN 1 ELSE 0 END) 6_7day,
sum(CASE WHEN a.takeoff_time >=a.first_send_notice_date + interval 7 DAY THEN 1 ELSE 0 END) 7DAY,
current_timestamp ETL_DTE
FROM FACT_matchedVideo a
JOIN DIM_trackingWebsite b ON a.trackingWebsite_id = b.trackingWebsite_id
WHERE a.first_send_notice_date >= date_format(‘FIRSTDAYOFLASTMONTH′,‘ANDa.firstsendnoticedate{FIRSTDAYOFCURMONTH}’, ‘%Y-%m-%d’)
AND a.count_send_notice> 0
AND a.hide_flag = 2
AND b.website_type in(‘ugc’,’hybrid’)
GROUP BY 1, 2
  

其中where过滤条件之一为:

a.first_send_notice_date >= date_format(‘${FIRSTDAYOFLASTMONTH}’, ‘%Y-%m-%d’)

在参数传递过来的时候,kettle的日期参数传递过来的时候,日期格式为:

‘yyyy-MM-dd HH:mm:ss’ 形式为 ‘2015/05/01 00:00:00’

数据库里面的日期格式为’yyyy-MM-dd HH:mm:ss’

那么两者比较的话就会出错,如下面的错误:

select ‘2015/05/01 00:00:00’ > ‘2015-05-02 00:00:00’;
+———————————————–+
| ‘2015/05/01 00:00:00’ > ‘2015-05-02 00:00:00’ |
+———————————————–+
| 1 |
+———————————————–+

】【打印繁体】【投稿】【收藏】 【推荐】【举报】【评论】 【关闭】 【返回顶部
分享到: 
上一篇Aerospike-Architecture系列之分.. 下一篇手动和自动启动多个oracle实例

评论

帐  号: 密码: (新用户注册)
验 证 码:
表  情:
内  容:

·如何从内核协议栈到 (2025-12-27 03:19:09)
·什么是网络协议?有哪 (2025-12-27 03:19:06)
·TCP/ IP协议有哪些 (2025-12-27 03:19:03)
·怎样用 Python 写一 (2025-12-27 02:49:19)
·如何学习python数据 (2025-12-27 02:49:16)