BigQuery的标准SQL中的日期和时间函数

BigQuery的标准SQL中的日期和时间函数

问题描述:

我试图在BigQuery的新标准SQL功能上使用我的MSSQL查询中的一个,因为它需要特殊的JOIN条件。但是,该引用不包含BigQuery标准SQL中日期时间函数的任何解释。BigQuery的标准SQL中的日期和时间函数

到目前为止,我设法我DATE_ADD声明 从转换:DATE_ADD( '2015年1月1日',-13, '月') 到:DATE_ADD( '2015年1月1日',间隔-13 MONTH)

我还将YEAR(x)转换为EXTRACT(YEAR FROM x)。两者似乎都是MySQL类似的语句。

最后,我注意到大多数日期函数的输出必须使用TIMESTAMP转换,然后才能比较它们。

但现在我的查询终于想运行我得到一个“内部错误”。任何人都知道什么可能是错的?这是查询:

SELECT 
    M, 
    Bought12MBeforeM, 
    Bought12MBeforeAndInM, 
    (Bought12MBeforeAndInM * 1.0)/(Bought12MBeforeAndInM + Bought12MBeforeM) AS RepurchaseRate 
FROM (
    SELECT 
    M, 
    COUNT(DISTINCT CASE WHEN MaxM < TIMESTAMP(M) THEN user_id ELSE NULL END) AS Bought12MBeforeM, 
    COUNT(DISTINCT CASE WHEN MaxM >= TIMESTAMP(M) 
     AND MinM < TIMESTAMP(M) THEN user_id ELSE NULL END) AS Bought12MBeforeAndInM 
    FROM (
    SELECT 
     M, 
     user_id, 
     MAX(cart_creation_date) AS MaxM, 
     MIN(cart_creation_date) AS MinM 
    FROM (
     SELECT 
     user_id, 
     cart_creation_date 
     FROM 
     `vex-eu-cloud-sql-001.work_user.flat_orders` 
     WHERE 
     cart_creation_date >= TIMESTAMP(DATE_ADD('2015-01-01', INTERVAL -13 MONTH)) 
     GROUP BY 
     user_id, 
     cart_creation_date) UniqueCarts 
    INNER JOIN (
     SELECT 
     DATE(Day) AS M 
     FROM 
     `vex-custom.wouter.days_2007_2020` 
     WHERE 
     EXTRACT(YEAR 
     FROM 
      Day) >= 2015 
     AND EXTRACT(DAY 
     FROM 
      Day) = 1 
     AND Day < TIMESTAMP(CURRENT_DATE())) Months 
    ON 
     cart_creation_date > TIMESTAMP(DATE_ADD(M, INTERVAL -13 MONTH)) 
     AND cart_creation_date < TIMESTAMP(DATE_ADD(M, INTERVAL 1 MONTH)) 
    GROUP BY 
     M, 
     user_id) BoughtInM 
    GROUP BY 
    M) Results 
+0

如果你提供工作的ID,我可以看一下是什么造成了内部错误 –

+0

没啥嗨,这是** vex-production:bquijob_343984cc_1545ef2e7a4 ** – Wouter

+0

好的,我在调查失败后更新了答案。 –

错误是由于在标准SQL的WHERE子句中处理TIMESTAMP的错误。目前的解决方法是UNIX_MICROS功能来包装它从TIMESTAMP到INT64翻译,那么你的查询工作:

SELECT 
    M, 
    Bought12MBeforeM, 
    Bought12MBeforeAndInM, 
    (Bought12MBeforeAndInM * 1.0)/(Bought12MBeforeAndInM + Bought12MBeforeM) AS RepurchaseRate 
FROM (
    SELECT 
    M, 
    COUNT(DISTINCT CASE WHEN MaxM < TIMESTAMP(M) THEN user_id ELSE NULL END) AS Bought12MBeforeM, 
    COUNT(DISTINCT CASE WHEN MaxM >= TIMESTAMP(M) 
     AND MinM < TIMESTAMP(M) THEN user_id ELSE NULL END) AS Bought12MBeforeAndInM 
    FROM (
    SELECT 
     M, 
     user_id, 
     MAX(cart_creation_date) AS MaxM, 
     MIN(cart_creation_date) AS MinM 
    FROM (
     SELECT 
     user_id, 
     cart_creation_date 
     FROM 
     `vex-eu-cloud-sql-001.work_user.flat_orders` 
     WHERE 
     UNIX_MICROS(cart_creation_date) >= UNIX_MICROS(TIMESTAMP(DATE_ADD('2015-01-01', INTERVAL -13 MONTH))) 
     GROUP BY 
     user_id, 
     cart_creation_date) UniqueCarts 
    INNER JOIN (
     SELECT 
     DATE(Day) AS M 
     FROM 
     `vex-custom.wouter.days_2007_2020` 
     WHERE 
     EXTRACT(YEAR FROM Day) >= 2015 
     AND EXTRACT(DAY FROM Day) = 1 
     AND UNIX_MICROS(Day) < UNIX_MICROS(TIMESTAMP(CURRENT_DATE()))) Months 
    ON 
     cart_creation_date > TIMESTAMP(DATE_ADD(M, INTERVAL -13 MONTH)) 
     AND cart_creation_date < TIMESTAMP(DATE_ADD(M, INTERVAL 1 MONTH)) 
    GROUP BY 
     M, 
     user_id) BoughtInM 
    GROUP BY 
    M) Results 
+0

好吧,试过,但得到了这个:_Error:TIMESTAMP_ADD不支持MONTH日期部分_ – Wouter

+0

该参考文献提到YEAR,DAY和其他日期部分函数。但所有这些给我:_Error:找不到函数:YEAR_ – Wouter

+0

我将更新文档以明确日期部分,如YEAR和DAY应在EXTRACT函数内部使用。 –