开发者社区 > 大数据与机器学习 > 大数据开发治理DataWorks > 正文

我在使用一张分区表时,该表无数据,能否让他不报错

FAILED: ODPS-0130071:[11,22] Semantic analysis exception - encounter runtime exception while evaluating function MAX_PT, detailed message: table "s_tof_finance_bt_payment" has no partitions or none of the partitions have any data

展开
收起
游客3oewgrzrf6o5c 2022-07-07 15:12:03 760 0
1 条回答
写回答
取消 提交回答
  • 全栈JAVA领域创作者

    您好,如果您使用的是 Oracle 数据库,那么可以通过在查询中使用“NULLIF”函数来处理分区表中不存在的分区。例如:

    SELECT NULLIF(MAX_PT('s_tof_finance_bt_payment', 'date_dim'), 'null') AS partition_value
    FROM s_tof_finance_bt_payment
    WHERE partition_date = '2022-01-01';
    

    这个查询会对分区表“s_tof_finance_bt_payment”的每个分区进行查询,并计算每个分区中的最大值。如果某个分区不存在,那么 MAX_PT 函数会返回 NULL,这时 NULLIF 函数会将 NULL 转换为“null”,从而避免报错。
    如果您使用的是其他数据库,那么可以考虑使用类似的方法来处理分区表中不存在的分区。

    2023-08-18 07:50:14
    赞同 展开评论 打赏

DataWorks基于MaxCompute/Hologres/EMR/CDP等大数据引擎,为数据仓库/数据湖/湖仓一体等解决方案提供统一的全链路大数据开发治理平台。

热门讨论

热门文章

相关电子书

更多
低代码开发师(初级)实战教程 立即下载
冬季实战营第三期:MySQL数据库进阶实战 立即下载
阿里巴巴DevOps 最佳实践手册 立即下载